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

标签 ios objective-c ios6 thread-safety dispatch-async

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

我正在尝试将大量数据插入到 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,但没有成功。因此,我们将不胜感激任何帮助,因为我对此非常绝望。

谢谢。干杯!

最佳答案

如果您调用 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/

相关文章:

ios - 隐藏键盘ios

ios - 如何从 iOS 6 中的推特获取用户信息?

ios - UIActivityViewController 崩溃,NSCFConstantString _beforeActivity 无法识别的选择器发送到实例

ios - 检测一个点是否在 MKPolygon 叠加层内

iphone - 错误 'autorelease' 不可用 : not available in automatic reference counting mode

ios - 使用数组项属性值显示在 UITableView/UICollectionView 中

iphone - 匹配一个或多个字母数字的 NSRegularExpression

ios - 如何在 UIButton 的左侧和右侧放置文本

objective-c - 对象请求失败 : Underlying HTTP request operation failed with error: Error Domain=NSURLErrorDomain Code=-1012 "

ios - 音频流播放: unable to change play/stop button image