iOS-FMDB事務【批次更新資料庫】,ios-fmdb交易資料庫

來源:互聯網
上載者:User

iOS-FMDB事務【批次更新資料庫】,ios-fmdb交易資料庫

開啟資料庫(sqlite)

///開啟資料庫+ (BOOL)openDataBase{       _TYDatabase = [[FMDatabase alloc]initWithPath:[self databasePath]];    if ([_TYDatabase open]) {        return YES;    }    return NO;}///資料庫路徑+ (NSString *)databasePath{    NSString *documentPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];    NSString *dataPath = [documentPath stringByAppendingPathComponent:@"TY.SQLite"];    NSFileManager *fileM = [NSFileManager defaultManager];    if (![fileM fileExistsAtPath:dataPath]) {        NSString *filePath = [[NSBundle mainBundle] pathForResource:@"TY" ofType:@"SQLite"];        [fileM copyItemAtPath:filePath toPath:dataPath error:nil];    }    NSLog(@"%@",dataPath);    return dataPath;    }

 

事務

/** 事務 arraySql:SQL語句數組 */- (void)beginTransaction:(NSArray *)arraySql;{    ////  static FMDatabase *_TYDatabase = nil;    BOOL isOpen=[_TYDatabase open];    if (!isOpen) {        NSLog(@"開啟資料庫失敗!");        return;    }    ///開始事物    [_TYDatabase beginTransaction];    BOOL isRollBack = NO;    @try {        for (int i = 0; i<arraySql.count; i++) {            BOOL result = [_TYDatabase executeUpdate:arraySql[i]];            if (!result) {                NSLog(@"操作失敗【%d】== SQL:%@",i,arraySql[i]);            }        }    }    @catch (NSException *exception) {        isRollBack = YES;        ///復原        [_TYDatabase rollback];    }    @finally {        if (!isRollBack) {            ///提交            [_TYDatabase commit];        }    }    [_TYDatabase close];}

 

多線程事務

/** 多線程事務 arraySql:SQL語句數組 */+ (void)beginTransactionT:(NSArray *)arraySql{    FMDatabaseQueue *databaseQueue = [FMDatabaseQueue databaseQueueWithPath:[self databasePath]];    [databaseQueue inTransaction:^(FMDatabase *db, BOOL *rollback) {        BOOL result = NO;        for (int i = 0; i < arraySql.count; i++) {            result = [_TYDatabase executeUpdate:arraySql[i]];        }        if (result) {            NSLog(@"成功");        }    }];}

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.