Android SQLite 事务处理

最近在做android项目的时候遇到一个问题,应用程序初始化时需要批量的向sqlite中插入大量数据,单独的使用for+Insert方法导致应用响应缓慢,因为 sqlite插入数据的时候默认一条语句就是一个事务,有多少条数据就有多少次磁盘操作。我的应用初始5000条记录也就是要5000次读写磁盘操作。
而且不能保证所有数据都能同时插入。(有可能部分插入成功,另外一部分失败,后续还得删除。太麻烦)

解决方法:

添加事务处理,把5000条插入作为一个事务


我们使用SQLite的事务进行控制:
              db.beginTransaction();   //手动设置开始事务
              try{
                     //批量处理操作
                     for(Collection c:colls){
                            insert(db, c);
                     }
                     db.setTransactionSuccessful (); //设置事务处理成功,不设置会自动回滚不提交
                   }catch(Exception e){
                          MyLog.printStackTraceString(e);
                   }finally{
                          db.endTransaction(); //处理完成
                   }

转:

1.使用SQLiteDatabase的beginTransaction()方法可以开启一个事务,程序执行到endTransaction() 方法时会检查事务的标志是否为成功,如果程序执行到endTransaction()之前调用了setTransactionSuccessful() 方法设置事务的标志为成功则提交事务,如果没有调用setTransactionSuccessful() 方法则回滚事务。

2.使用例子如下:下面两条SQL语句在同一个事务中执行。

Java代码
  1. //银行账户事务测试  
  2. public void payment()  
  3.  
  4.     SQLiteDatabase db dbOpenHelper.getWritableDatabase();  
  5.     //开启事务  
  6.     db.beginTransaction();  
  7.     try  
  8.      
  9.         db.execSQL("update person set amount=amount-10 where personid=?"new Object[]{1});  
  10.         db.execSQL("update person set amount=amount+10 where personid=?"new Object[]{2});  
  11.         //设置事务标志为成功,当结束事务时就会提交事务  
  12.         db.setTransactionSuccessful();  
  13.      
  14.     finally  
  15.      
  16.         //结束事务  
  17.         db.endTransaction();  
  18.      
  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值