所以,我已经阅读了我在互联网上找到的所有帖子,但我似乎仍然无法完成这项工作。
我正在尝试将大量数据插入 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-推荐答案 strong>
如果您调用 InsertDataIntoTable 两次,或尝试访问数据库的任何其他方法,您可能会遇到数据库连接在您有时间执行查询之前关闭的情况。
考虑这种情况:
- 线程 1 打开数据库连接
- 线程 2 打开数据库连接
- 线程 1 向队列中添加一个 block
- 线程 2 向队列中添加一个 block
- 线程 1 完成运行并关闭数据库连接
- 线程 2 尝试运行他的 block ,但数据库连接已经关闭。
尝试在 block 内调用[数据库打开] 。
关于ios - 使用 FMDB 将数据插入 SQLite 时 dispatch_async 上的 EXC_BAD_ACCESS,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/15494482/
|