• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

ios - 使用 FMDB 将数据插入 SQLite 时 dispatch_async 上的 EXC_BAD_ACCESS

[复制链接]
菜鸟教程小白 发表于 2022-12-12 09:46:43 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

所以,我已经阅读了我在互联网上找到的所有帖子,但我似乎仍然无法完成这项工作。

我正在尝试将大量数据插入 sqlite 数据库。这是20000行数据,所以我必须在后台线程中进行。

我有一个 NSObject .h 和 .m 文件来处理数据库操作。我从我的主视图中调用它们。

这是我的代码:

SQLiteDBHandler.m :

 database = [FMDatabase databaseWithPath:[self getDBPath]];
    [database open];
    dispatch_queue_t q = dispatch_queue_create("FMDBQueue", NULL);
    dispatch_async(q, ^{
        for(Customer *c in arrayOfObjects) {
            [database executeUpdate"INSERT INTO SNP(rdis, Position, FirstName, LastName) VALUES (?,?,?,?)", c.ID, c.Position, c.FirstName, c.LastName];
        }
        [database close];
    });

为了在主视图中调用方法,我这样调用它:

SQLiteDBHandler *dbHandler = [[SQLiteDBHandler alloc]init];

[dbHandler insertDataIntoTable:mutableArray];

我尝试使用 FMDatabaseQueue 更改 FMDatabase,但没有成功。因此,任何帮助都将受到高度赞赏,因为我对此非常绝望。

谢谢。干杯!



Best Answer-推荐答案


如果您调用 InsertDataIntoTable 两次,或尝试访问数据库的任何其他方法,您可能会遇到数据库连接在您有时间执行查询之前关闭的情况。 考虑这种情况:

  1. 线程 1 打开数据库连接
  2. 线程 2 打开数据库连接
  3. 线程 1 向队列中添加一个 block
  4. 线程 2 向队列中添加一个 block
  5. 线程 1 完成运行并关闭数据库连接
  6. 线程 2 尝试运行他的 block ,但数据库连接已经关闭。

尝试在 block 内调用[数据库打开]

关于ios - 使用 FMDB 将数据插入 SQLite 时 dispatch_async 上的 EXC_BAD_ACCESS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15494482/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap