SQLite(FMDB) 线程安全 - 多线程处理

SQLite(FMDB) 线程安全 - 多线程处理,第1张

概述http://www.saick.net/blog/2013/12/12/sqlite-xian-cheng-an-quan-duo-xian-cheng-chu-li/ 在iOS开发中,经常用到SQLite,CoreData也不错,但很多时候还是自己写sql,使用FMDB来处理。当然了,也可以不用FMDB,直接写处理,这个不解释。 但是,我们在数据库 *** 作的时候,经常遇到多线程访问数据库的状况,常

http://www.saick.net/blog/2013/12/12/sqlite-xian-cheng-an-quan-duo-xian-cheng-chu-li/


在iOS开发中,经常用到sqlite,CoreData也不错,但很多时候还是自己写sql,使用FMDB来处理。当然了,也可以不用FMDB,直接写处理,这个不解释。

但是,我们在数据库 *** 作的时候,经常遇到多线程访问数据库的状况,常见的有几种处理方法:

1,NSLock或类似方法加锁 2,FMDatabaseQueue 3,sqlITE_CONfig_SERIAliZED

下面我们来仔细看一下出现的问题以及相关的解决方案

常见问题

以使用FMDB为例:

The deBUGger says that the error occurs at [FMResultSet next] at the line,hasEXC_BAD_ACCESS

1
rc = sqlite3_step(statement.statement);

多线程访问的时候,会在这里报错。

如何解决呢?

1. NSLock加锁(NSMutex)

详见苹果官方文档:Threading Programming Guide

2. FMDatabaseQueue

这个是我在某项目中用到的,所有查询都走这里。 可能因为项目较复杂,用了这个还是会时候有问题,但稳定很多。可以有一些别的地方调用,没查清楚。

1234567891011121314151617181920212223
// 相关引用 _fmQueue = [FMDatabaseQueue databaseQueueWithPath:sqlitePath];  // 查询数据 - (FMResultSet *)executequeryWithsql:(Nsstring *)sql {  BFLogVerbose(@"executequery: %@",sql);   __block FMResultSet *rs = nil;  __block dispatch_semaphore_t sem = dispatch_semaphore_create(0);   [_fmQueue inDatabase:^(FMDatabase *fmdb){  FMResultSet *tmpRs = [fmdb executequery:sql];  rs = [FMResultSet resultSetWithStatement:tmpRs.statement usingParentDatabase:fmdb];  [tmpRs close];  dispatch_semaphore_signal(sem);  }];   dispatch_semaphore_wait(sem,disPATCH_TIME_FOREVER);  dispatch_release(sem);   return rs; }
3. sqlITE_CONfig_SERIAliZED

sqlite provIDes a much simpler serialization. By just setting the sqlite_config() option sqlITE_CONfig_SERIAliZED you will probably avoID most of these kinds of headaches. I discovered this the hard way after fighting with threading issues for a long while.

3
if (sqlite3_config(sqlITE_CONfig_SERIAliZED) == sqlITE_ERROR) {  NSLog(@"Couldn't set serialized mode"); }

参考:http://stackoverflow.com/questions/3144700/exc-bad-access-when-using-sqlite-fmdb-and-threads-on-ios-4-0

总结

以上是内存溢出为你收集整理的SQLite(FMDB) 线程安全 - 多线程处理全部内容,希望文章能够帮你解决SQLite(FMDB) 线程安全 - 多线程处理所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/1172436.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-02
下一篇2022-06-02

发表评论

登录后才能评论

评论列表(0条)

    保存