sqlite比較常規的使用方式一般是這樣的,就是在程式中建立一個空的資料庫,然後進行增刪改查等一系列的操作,這樣的操作,對於小應用的開發是比較容易滿足需求的,但是有些比較大的應用,包含的資料量比較大,如果在程式中,對資料進行一條一條的插入,第一,比較耗時,第二,使用者體驗很差,最重要的一點是顯得很不專業。那麼,可以想到的一種比較好的方式,就是如何將db檔案與apk一起安裝到手機上呢,實現方法如下:
首先,要有包含資料的sqlite檔案,是db類型的,可以是你之前一條一條匯入的,然後找到手機路徑下/data/data/包名/database檔案,將其匯出就可以了;
然後,再android工程裡找到assets目錄,將db類型的檔案放在該目錄下面,準備就緒之後,上代碼
[java]
public static SQLiteDatabase database;
public static SQLiteDatabase database;[java] view plaincopyprint?String DB_PATH = "/data/data/com.example.mymap/databases/";
String DB_NAME = "wifi.db";
// 檢查 SQLite 資料庫檔案是否存在
if ((new File(DB_PATH + DB_NAME)).exists() == false) {
// 如 SQLite 資料庫檔案不存在,再檢查一下 database 目錄是否存在
File f = new File(DB_PATH);
// 如 database 目錄不存在,建立該目錄
if (!f.exists()) {
f.mkdir();
}
try {
// 得到 assets 目錄下我們實現準備好的 SQLite 資料庫作為輸入資料流
InputStream is = getBaseContext().getAssets().open(DB_NAME);
// 輸出資料流
OutputStream os = new FileOutputStream(DB_PATH + DB_NAME);
// 檔案寫入
byte[] buffer = new byte[1024];
int length;
while ((length = is.read(buffer)) > 0) {
os.write(buffer, 0, length);
}
// 關閉檔案流
os.flush();
os.close();
is.close();
} catch (Exception e) {
e.printStackTrace();
}
}
// 下面測試 /data/data/com.test.db/databases/ 下的資料庫是否能正常工作
database = SQLiteDatabase.openOrCreateDatabase(DB_PATH + DB_NAME, null);
Cursor cursor = database.rawQuery("select * from wifi_private", null);//這句話沒通過
Log.v("111","111");
if (cursor.getCount() > 0) {
cursor.moveToFirst();
// 解決中文亂碼問題
String SSID = cursor.getString(cursor.getColumnIndex("SSID"));
//byte test[] = cursor.getBlob(0);
//String strtest = new String(test, "utf-8").trim();
// 看輸出的資訊是否正確
Log.v("SSID",""+SSID);
}
cursor.close();
Log.v("222","222");
String DB_PATH = "/data/data/com.example.mymap/databases/";
String DB_NAME = "wifi.db";
// 檢查 SQLite 資料庫檔案是否存在
if ((new File(DB_PATH + DB_NAME)).exists() == false) {
// 如 SQLite 資料庫檔案不存在,再檢查一下 database 目錄是否存在
File f = new File(DB_PATH);
// 如 database 目錄不存在,建立該目錄
if (!f.exists()) {
f.mkdir();
}
try {
// 得到 assets 目錄下我們實現準備好的 SQLite 資料庫作為輸入資料流
InputStream is = getBaseContext().getAssets().open(DB_NAME);
// 輸出資料流
OutputStream os = new FileOutputStream(DB_PATH + DB_NAME);
// 檔案寫入
byte[] buffer = new byte[1024];
int length;
while ((length = is.read(buffer)) > 0) {
os.write(buffer, 0, length);
}
// 關閉檔案流
os.flush();
os.close();
is.close();
} catch (Exception e) {
e.printStackTrace();
}
}
// 下面測試 /data/data/com.test.db/databases/ 下的資料庫是否能正常工作
database = SQLiteDatabase.openOrCreateDatabase(DB_PATH + DB_NAME, null);
Cursor cursor = database.rawQuery("select * from wifi_private", null);//這句話沒通過
Log.v("111","111");
if (cursor.getCount() > 0) {
cursor.moveToFirst();
// 解決中文亂碼問題
String SSID = cursor.getString(cursor.getColumnIndex("SSID"));
//byte test[] = cursor.getBlob(0);
//String strtest = new String(test, "utf-8").trim();
// 看輸出的資訊是否正確
Log.v("SSID",""+SSID);
}
cursor.close();
Log.v("222","222");
這樣一來 資料庫就匯入成功了,需要注意的一點,該匯入進去的資料庫並不會和你程式中建立的資料庫產生衝突(只要資料庫名不同,表名相不相同無所謂),所以,有些資料是安裝程式的同時匯入,有些資料也可以在程式中根據使用者個人的操作進行添加,並不會產生衝突。