android批量插入数据效率对比

时间:2023-03-09 17:00:45
android批量插入数据效率对比

对比在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