码迷,mamicode.com
首页 > 移动开发 > 详细

android事务操作

时间:2014-10-22 14:16:50      阅读:129      评论:0      收藏:0      [点我收藏+]

标签:android   style   blog   http   color   io   ar   for   strong   

  原文路径:http://blog.csdn.net/w250shini11/article/details/8649289

  最近有个客户反映,需要导入十几万的数据到sqlite,结果耗时很长,并且很容易崩溃。网上搜了下解决办法,看到了以下这个觉着靠谱的想法,但手上还没有相应的大量数据进行测试,先将方法保留下来。

  在Android开发中,需要向sqlite中导入大量数据,按照一般做法是很耗时的,测试了一下,导入一条数据在100ms左右,按照这样的做法,如果导入1万条数据,大约得花17分钟,经过实际测试,确实花了17分钟左右。

解决耗时的办法是利用sqlite的事务来处理。方法如下:

首先获取database对象,然后执行如下方法:

db.beginTransaction();      //手动设置开始事务 
//数据插入操作循环 

//update insert delete select可以循环嵌套操作 
db.setTransactionSuccessful();        //设置事务处理成功,不设置会自动回滚不提交 
db.endTransaction();        //处理完成

测试了一下,如果导入1万条数据,大约耗时20秒左右。性能比之前提升了一大截。比如

    public int insert(Uri uri, ContentValues[] values) {

        SQLiteDatabase db = mOpenHelper.getWritableDatabase();

        db.beginTransaction();

        try {

            int numValues = values.length;

            for (int i = 0; i < numValues; i++) {

                   db.insertOrThrow(tablename, null, values);

            }

            db.setTransactionSuccessful();

        } finally {

            db.endTransaction();

        }

         return values.length;

    }

android事务操作

标签:android   style   blog   http   color   io   ar   for   strong   

原文地址:http://www.cnblogs.com/dream550/p/4042963.html

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