对比在android中批量插入数据的3中方式对比(各插入1W条数据所花费的时间):

1、 一个一个插入

  1. /**
  2. * 向表中插入数据
  3. *
  4. * @param openHelper
  5. * @param appInfo
  6. * @return
  7. */
  8. public static boolean insert(SQLiteOpenHelper openHelper,
  9. RemoteAppInfo appInfo) {
  10. if (null == appInfo) {
  11. return true;
  12. }
  13. SQLiteDatabase db = null;
  14. try {
  15. db = openHelper.getWritableDatabase();
  16. ContentValues values = appInfo.getContentValues();
  17. != db.insert(RemoteDBHelper.TABLE_APP_REMOTE, null,
  18. values);
  19. } catch (Exception e) {
  20. e.printStackTrace();
  21. } finally {
  22. if (null != db) {
  23. db.close();
  24. }
  25. }
  26. return false;
  27. }
  28. for (RemoteAppInfo remoteAppInfo : list) {
  29. RemoteDBUtil.insert(helper, remoteAppInfo);
  30. }

 耗时:106524ms,也就是106s

2、 开启事务批量插入,使用

SqliteDateBase中的

insert(String table, String nullColumnHack, ContentValues values)

方法

  1. /**
  2. * 向表中插入一串数据
  3. *
  4. * @param openHelper
  5. * @param appInfo
  6. * @return 如果成功则返回true,否则返回flase
  7. */
  8. public static boolean insert(SQLiteOpenHelper openHelper,
  9. List<RemoteAppInfo> list) {
  10. boolean result = true;
  11. ) {
  12. return true;
  13. }
  14. SQLiteDatabase db = null;
  15. try {
  16. db = openHelper.getWritableDatabase();
  17. db.beginTransaction();
  18. for (RemoteAppInfo remoteAppInfo : list) {
  19. ContentValues values = remoteAppInfo.getContentValues();
  20. ) {
  21. result = false;
  22. break;
  23. }
  24. }
  25. if (result) {
  26. db.setTransactionSuccessful();
  27. }
  28. } catch (Exception e) {
  29. e.printStackTrace();
  30. return false;
  31. } finally {
  32. try {
  33. if (null != db) {
  34. db.endTransaction();
  35. db.close();
  36. }
  37. } catch (Exception e) {
  38. e.printStackTrace();
  39. }
  40. }
  41. return true;
  42. }

耗时:2968ms

3、 开启事务批量插入,使用

SQLiteStatement

  1. /**
  2. * 第二种方式批量插入(插入1W条数据耗时:1365ms)
  3. * @param openHelper
  4. * @param list
  5. * @return
  6. */
  7. public static boolean insertBySql(SQLiteOpenHelper openHelper,
  8. List<RemoteAppInfo> list) {
  9. ) {
  10. return false;
  11. }
  12. SQLiteDatabase db = null;
  13. try {
  14. db = openHelper.getWritableDatabase();
  15. String sql = "insert into " + RemoteDBHelper.TABLE_APP_REMOTE + "("
  16. + RemoteDBHelper.COL_PKG_NAME + ","// 包名
  17. + RemoteDBHelper.COL_USER_ACCOUNT + ","// 账号
  18. + RemoteDBHelper.COL_APP_SOURCE + ","// 来源
  19. + RemoteDBHelper.COL_SOURCE_UNIQUE + ","// PC mac 地址
  20. + RemoteDBHelper.COL_MOBILE_UNIQUE + ","// 手机唯一标识
  21. + RemoteDBHelper.COL_IMEI + ","// 手机IMEI
  22. + RemoteDBHelper.COL_INSTALL_STATUS + ","// 安装状态
  23. + RemoteDBHelper.COL_TRANSFER_RESULT + ","// 传输状态
  24. + RemoteDBHelper.COL_REMOTE_RECORD_ID // 唯一标识
  25. + ") " + "values(?,?,?,?,?,?,?,?,?)";
  26. SQLiteStatement stat = db.compileStatement(sql);
  27. db.beginTransaction();
  28. for (RemoteAppInfo remoteAppInfo : list) {
  29. , remoteAppInfo.getPkgName());
  30. , remoteAppInfo.getAccount());
  31. , remoteAppInfo.getFrom());
  32. , remoteAppInfo.getFromDeviceMd5());
  33. , remoteAppInfo.getMoblieMd5());
  34. , remoteAppInfo.getImei());
  35. , remoteAppInfo.getInstallStatus());
  36. , remoteAppInfo.getTransferResult());
  37. , remoteAppInfo.getRecordId());
  38. long result = stat.executeInsert();
  39. ) {
  40. return false;
  41. }
  42. }
  43. db.setTransactionSuccessful();
  44. } catch (Exception e) {
  45. e.printStackTrace();
  46. return false;
  47. } finally {
  48. try {
  49. if (null != db) {
  50. db.endTransaction();
  51. db.close();
  52. }
  53. } catch (Exception e) {
  54. e.printStackTrace();
  55. }
  56. }
  57. return true;
  58. }

耗时:1365ms

android批量插入数据效率对比的更多相关文章

  1. Android 批量插入数据到SQLite数据库

    Android中在sqlite插入数据的时候默认一条语句就是一个事务,因此如果存在上万条数据插入的话,那就需要执行上万次插入操作,操作速度可想而知.因此在Android中插入数据时,使用批量插入的方式 ...

  2. Android批量插入数据到SQLite数据库

    Android中在sqlite插入数据的时候默认一条语句就是一个事务,因此如果存在上万条数据插入的话,那就需要执行上万次插入操作,操作速度可想而知.因此在Android中插入数据时,使用批量插入的方式 ...

  3. JDBC批量插入数据效率分析

    对于需要批量插入数据库操作JDBC有多重方式,本利从三个角度对Statement和PreparedStatement两种执行方式进行分析,总结较优的方案. 当前实现由如下条件: 执行数据库:Mysql ...

  4. Oracle 逐条和批量插入数据方式对比

    创建测试表 create table base_users ( userid         varchar2(16), username  varchar2(32), passwd      var ...

  5. Oracle 插入数据效率对比

    oracle插入数据有多种方式: 将从多个表中查出来的数据插入到临时表中 数据行数 5189597 1.传统方式:直接将数据插入到表中 insert into LLB_BASIC_USER_D_TEM ...

  6. EF批量插入数据耗时对比

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  7. MySQL:JDBC批量插入数据的效率

    平时使用mysql插入.查询数据都没有注意过效率,今天在for循环中使用JDBC插入1000条数据居然等待了一会儿 就来探索一下JDBC的批量插入语句对效率的提高 首先进行建表 create tabl ...

  8. 批量插入数据(基于Mybatis的实现-Oracle)

    前言:做一个数据同步项目,要求:同步数据不丢失的情况下,提高插入性能. 项目DB框架:Mybatis.DataBase:Oracle. -------------------------------- ...

  9. SpringBoot(18)---通过Lua脚本批量插入数据到Redis布隆过滤器

    通过Lua脚本批量插入数据到布隆过滤器 有关布隆过滤器的原理之前写过一篇博客: 算法(3)---布隆过滤器原理 在实际开发过程中经常会做的一步操作,就是判断当前的key是否存在. 那这篇博客主要分为三 ...

随机推荐

  1. [svc]Linux中Swap与Memory内存简单介绍

    swap区域是干嘛的 cpu 内存(不常用到的进程swap区) 磁盘 当内存没有可用的,就必须要把内存中不经常运行的程序给踢出去.但是踢到哪里去,这时候swap就出现了. 背景介绍 对于Linux来说 ...

  2. 菜鸟调错(三)——Jboss与jdk版本不兼容导致WebService调用出错

    环境: jdk1.6 Jboss 5.1.0.GA 问题描述: EJB发布webserivce已经成功,并且能够成功访问wsdl文件: 使用axis1自带的sample/client下的类Dynami ...

  3. Stochastic Gradient Descent收敛判断及收敛速度的控制

    要判断Stochastic Gradient Descent是否收敛,可以像Batch Gradient Descent一样打印出iteration的次数和Cost的函数关系图,然后判断曲线是否呈现下 ...

  4. 关于CAE的那点儿破事儿

    CAE是计算机辅助工程的英文简写,所涵盖的范围甚是广泛.现在很多人提到CAE,总是联想到结构有限元计算,更有甚者认为有限元就是CAE.还有人把所有的工程数值计算都称作有限元.本文就这一话题,来谈谈关于 ...

  5. Linux 守护进程

    1.什么是守护进程 守护进程daemon指的是在后台运行的进程 2.前台任务和后台任务 前台任务:独占命令行窗口,运行完毕或手动终止,才能执行其他命令 以redis服务为例 redis-server ...

  6. [mBean]-Delphi框架,回归简单,自然。

    [mBean]的萌芽 最近公司要求把我们公司的任务可以外包,问我有没有好的方案. 如果要其他程序员的人来做我们内部的框架会导致了,内部的框架需要公布很多单元和逻辑,思路.其次要把我们的思路和规则强加给 ...

  7. flex布局知识点(阮一峰博客)

    任何一个容器都可以指定为flex布局: 行内元素也可以使用flex布局: 设为flex布局以后,子元素的float,clear,vertical-align属性都将失效: flex容器的属性: fle ...

  8. 获取windows可执行文件的version信息(版本号)

    之前在msdn上Version Information看到文件版本信息的介绍,看着整体比较复杂,就一直没做.现在需要获取ocx文件的版本号,所以查找了下相关资料,比较有用的就是VS_FIXEDFILE ...

  9. BAT-增加JAVA环境变量(WIN764位)

    相关资料:1.http://www.jb51.net/article/52756.htm2.http://blog.csdn.net/fireghost57/article/details/21103 ...

  10. 基于jQuery仿QQ音乐播放器网页版代码

    基于jQuery仿QQ音乐播放器网页版代码是一款黑色样式风格的网页QQ音乐播放器样式代码.效果图如下: 在线预览   源码下载 实现的代码. html代码: <div class="m ...