码迷,mamicode.com
首页 > 数据库 > 详细

FMDB批量插入数据

时间:2017-03-01 12:22:55      阅读:243      评论:0      收藏:0      [点我收藏+]

标签:事务处理   pen   插入   速度   mit   self   suse   情况   bool   

做本地存储的时候,很多情况我们希望能够进行批量插入,很遗憾sqlite并未提供这样的语句,但是我们同样可以实现同样的效果,毕竟sqlite号称是支持每秒5万条的数据存储,下面说方法.

解决方法:事务处理

从根本上来说,这是一种伪批量插入,但是速度却大大提升,几百上千条的数据基本0.04秒左右就能完成.如果不做的话,它会默认为每一条都做事务处理,所以很慢.

不多说了,上代码:

- (void)insertStudentsUseTransaction:(NSArray<StudentEntity *>*)students {

    [self.db open];
    [self.db beginTransaction];
    BOOL isRollBack = NO;
    @try {
        for (StudentEntity *studentEntity in students) {
            BOOL isSuccess = [self.db executeUpdate:@"insert into StuList(sid, user_id, realname, avatar_url, isyjmember) values(?,?,?,?,?)", studentEntity.sid, studentEntity.user_id, studentEntity.realname, studentEntity.avatar_url, studentEntity.isyjmember];
            NSLog(@"%@", isSuccess ? @"插入学生数据成功" : @"插入学生数据失败");
        }
    } @catch (NSException *exception) {
        isRollBack = YES;
        [self.db rollback];
    } @finally {
        if (!isRollBack) {
            [self.db commit];
        }
    }
    [self.db close];
}

 

FMDB批量插入数据

标签:事务处理   pen   插入   速度   mit   self   suse   情况   bool   

原文地址:http://www.cnblogs.com/liuzicheng/p/6483355.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!