首页 > 代码库 > FMDB批量插入数据
FMDB批量插入数据
做本地存储的时候,很多情况我们希望能够进行批量插入,很遗憾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批量插入数据
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。