FMDatabaseQueue

首先用一个数据库文件地址来初使化FMDatabaseQueue,然后就可以将一个闭包(block)传入inDatabase方法中。 在闭包中操作数据库,而不直接参与FMDatabase的管理。

FMDatabaseQueue解决这个问题的思路是:创建一个队列,然后将放入队列的block顺序执行,这样避免了多线程同时访问数据库;

如果是多线程各创建FMDatabaseQueue的实例,其实有多个队列,还是存在数据库竞争的问题,和用FMDatabase时是一样的;

让每个线程使用同一个Queue实例,问题就解决了!

@property (nonatomic, strong) FMDatabaseQueue *commonQueue;

NSString *commonQueuePath = [NSFileManager pathDBCommon];

self.commonQueue = [FMDatabaseQueue databaseQueueWithPath:commonQueuePath];

重点是这个!!!

- (void)excuteQuerySQL:(NSString*)sqlStr resultBlock:(void(^)(FMResultSet * rsSet))resultBlock

{

      if (self.dbQueue) {

         [_dbQueue inDatabase:^(FMDatabase *db) {

         FMResultSet * retSet = [db executeQuery:sqlStr];

         if (resultBlock) {

             resultBlock(retSet);

         }

      }];

   }

你可能感兴趣的:(FMDatabaseQueue)