FMDB 修改FMdatabase.m文件,不使用FMDatabaseQueue支持多線程數(shù)據(jù)庫操作

眾所周知,要使FMDB支持多線程操作,需要使用FMDatabaseQueue,
覺得FMDatabaseQueue這種block回調(diào)方式使用不方便的可以用以下方式實(shí)現(xiàn)數(shù)據(jù)庫單連接支持多線程操作:

  • 修改FMDatabase.m文件 open 方法

- (BOOL)open {
    if (_db) {
        return YES;
    }
    
/** 添加以下兩句*/
     /** add by xxx at 20151119 begin*/
    sqlite3_shutdown();
    
    sqlite3_config(SQLITE_CONFIG_SERIALIZED);
    
    /** add by xxx at 20151119 end*/
    
    int err = sqlite3_open([self sqlitePath], &_db );
    if(err != SQLITE_OK) {
        NSLog(@"error opening!: %d", err);
        return NO;
    }
    
    if (_maxBusyRetryTimeInterval > 0.0) {
        // set the handler
        [self setMaxBusyRetryTimeInterval:_maxBusyRetryTimeInterval];
    }
    
    
    return YES;
}
  • 注釋 FMDatabase.m文件 中出現(xiàn)if (_isExecutingStatement)的地方,總共有4

- (sqlite_int64)lastInsertRowId {
    
//    if (_isExecutingStatement) {
//        [self warnInUse];
//        return NO;
//    }
    
    _isExecutingStatement = YES;
    
    sqlite_int64 ret = sqlite3_last_insert_rowid(_db);
    
    _isExecutingStatement = NO;
    
    return ret;
}

- (int)changes {
//    if (_isExecutingStatement) {
//        [self warnInUse];
//        return 0;
//    }
    
    _isExecutingStatement = YES;
    
    int ret = sqlite3_changes(_db);
    
    _isExecutingStatement = NO;
    
    return ret;
}

....

現(xiàn)在可以直接使用FMdatabase進(jìn)行多線程操作了,不必使用FMDatabaseQueue這種block回調(diào)方式,代碼簡潔又易懂。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容