Android:Sqlite插入大批量数据

假如现在要向Android本地数据库中插入1万条数据。按照一般的想法代码如下:

//假设strings.size() = 10000
    try {
        for (String data : strings) {
            ContentValues contentValues = new ContentValues();
            if(!TextUtils.isEmpty(data)){
                contentValues.put(key, data);
            }
            mDb.insert(table_name, null, contentValues);
        }
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        mDb.close();
    }

如上做法可能会花费大概2minute,这是因为每次插入都会创建一次事务。在看看下面这段代码:

//假设strings.size() = 10000
try {
        mDb.beginTransaction();
        for (String data : strings) {
            ContentValues contentValues = new ContentValues();
            if(!TextUtils.isEmpty(data)){
                contentValues.put(key, data);
            }
            mDb.insert(table_name, null, contentValues);
        }
        mDb.setTransactionSuccessful();
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        mDb.endTransaction();
        mDb.close();
    }

比第一段多了3行,但插入操作花费的时间只需要4s左右,这是因为我们主动开启了一个事务,所以整个插入操作实在一个事务中完成的,花费的时间也大大的减少了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,632评论 25 709
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,955评论 18 399
  • 淘汰机制! 社会中存在赢家,就存在输家,那么背后淘汰机制,能解释他们是怎么输掉的,也能解释他们是怎么赢的! 个人...
    柏拉图的阅读 1,618评论 0 1
  • 由于自己项目中需要弹窗的地方很多。。所以找了资料自己写了一个简单的。。喜欢的自己拿去用吧。希望能帮助一些同学。不多...
    追梦小怪兽阅读 5,807评论 0 0
  • 如果有一个男人来信皆是情书,如果他视你为精神性的彼岸—维纳斯女神,如果他才华横溢写的每句情话恰入你心,如果他爱你如...
    三更归梦一介舟阅读 3,950评论 0 4