這兩天被資料庫插入批量資料折磨的有點抓狂還好找到瞭解決方法,話不多說,直接看下面兩部分代碼:
SQLiteDatabase db = dbHelper.getWritableDatabase();
// LogUtils.i("開始解析*****************"+ new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
for (int i = 0; i < messageArray.length(); i++) {
try {
JSONObject messageObject = (JSONObject) messageArray.get(i);
int stamp = JSONUtils.getInt(messageObject, "nTime", 0);
String dbLon = JSONUtils.getString(messageObject, "dbLon", "");
String dbLat = JSONUtils.getString(messageObject, "dbLat", "");
/******************** 資料庫事務開始 **************************/
db.beginTransaction();
db.execSQL("insert into waybaby(stamp,lontude,lantude) values(?,?,?)",new Object[] { stamp, dbLon,dbLat });
db.setTransactionSuccessful();
db.endTransaction();
/******************** 資料庫事務結束 **************************/
tranceList.add(Double.parseDouble(dbLat));
tranceList.add(Double.parseDouble(dbLon));
LatLng latLng = new LatLng(Double.parseDouble(dbLat), Double.parseDouble(dbLon));
latLngline.add(latLng);
} catch (JSONException e) {
e.printStackTrace();
}
}
dismissProgressDialog();
// LogUtils.i("解析結束*****************"+ new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
// 畫路線軌跡
onMapLoaded();
這段代碼是用來解析資料的,然後插入到本機資料庫裡面,總共:1000 條資料,用時:10秒~~15秒。十五秒的等待,花兒都謝了。請看下面修改後的代碼:
SQLiteDatabase db = dbHelper.getWritableDatabase();
// LogUtils.i("開始解析*****************"+ new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
for (int i = 0; i < messageArray.length(); i++) {
try {
JSONObject messageObject = (JSONObject) messageArray.get(i);
int stamp = JSONUtils.getInt(messageObject, "nTime", 0);
String dbLon = JSONUtils.getString(messageObject, "dbLon", "");
String dbLat = JSONUtils.getString(messageObject, "dbLat", "");
LocusEntity locusEntity = new LocusEntity(stamp, dbLon, dbLat);
locusEntities.add(locusEntity);
tranceList.add(Double.parseDouble(dbLat));
tranceList.add(Double.parseDouble(dbLon));
LatLng latLng = new LatLng(Double.parseDouble(dbLat), Double.parseDouble(dbLon));
latLngline.add(latLng);
} catch (JSONException e) {
e.printStackTrace();
}
}
// LogUtils.i("開始插入資料*****************"+ new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
db.beginTransaction();
String sql = "insert into waybaby(stamp,lontude,lantude) values(?,?,?)";
for (LocusEntity locusEntity : locusEntities) {
SQLiteStatement stat = db.compileStatement(sql);
stat.bindLong(1, locusEntity.getStamp());
stat.bindString(2, locusEntity.getLontude());
stat.bindString(3, locusEntity.getLantude());
stat.executeInsert();
}
db.setTransactionSuccessful();
db.endTransaction();
db.close();
// LogUtils.i("插入資料完畢*****************"+ new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
dismissProgressDialog();
// LogUtils.i("解析結束*****************"+ new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
// 畫路線軌跡
onMapLoaded();
細心的你,肯定會發現,插入資料的操作,被拿到了for迴圈的外面,同時插入資料庫的操作也改變了,多了一大段代碼,從一行變成了十幾行,但是效率提高的不是一點兩點。這段代碼執行的時間: 不到 1 秒,列印的時間資訊,你會發現,時間不用1秒 就擷取成功了。我列印的時間就不到 1 秒。比之前的效率快的將近十倍,你敢信? 事實就是如此。至於那段代碼是什麼意思。請自行百度,自己學習。