我的ios应用程序使用FMDB框架来使用SQLite数据库。要从服务器更新数据库,我使用FMDatabaseQueue:
- (BOOL)executeUpdate:(NSString *)update
{
FMDatabaseQueue *dbQueue = [FMDatabaseQueue databaseQueueWithPath:databasePath];
__block BOOL success = NO;
[dbQueue inTransaction:^(FMDatabase *db, BOOL *rollback) {
success = [db executeUpdate: update];
}];
return success;
}
这种方法允许我使用多个线程来处理数据库。但查询将按接收顺序执行。当我更新数据库中的大块数据时,其他查询(比如获取UI线程的一些数据)必须等待太长时间。 有没有办法允许其他查询在更新过程中读取提交的数据?(如JDBC隔离级别TRANSACTION_READ_COMMITTED)