Android運用開辟之將SQLite和APK一路打包的辦法。本站提示廣大學習愛好者:(Android運用開辟之將SQLite和APK一路打包的辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是Android運用開辟之將SQLite和APK一路打包的辦法正文
在 Eclipse 裡新建好工程後,默許會有一個assets目次,在 Eclipse 中直接將預備好的 SQLite 數據庫復制到該目次中,然後在主 Activity 外面編碼:
package com.test.db; import java.io.File; import java.io.FileOutputStream; import java.io.InputStream; import java.io.OutputStream; import java.io.UnsupportedEncodingException; import android.app.Activity; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.os.Bundle; public class DbtestActivity extends Activity { /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); // com.test.db 是法式的包名,請依據本身的法式調劑 // /data/data/com.test.db/ // databases 目次是預備放 SQLite 數據庫的處所,也是 Android 法式默許的數據庫存儲目次 // 數據庫名為 test.db String DB_PATH = "/data/data/com.test.db/databases/"; String DB_NAME = "test.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/ 下的數據庫能否能正常任務 SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(DB_PATH + DB_NAME, null); Cursor cursor = database.rawQuery("select * from test", null); if (cursor.getCount() > 0) { cursor.moveToFirst(); try { // 處理中文亂碼成績 byte test[] = cursor.getBlob(0); String strtest = new String(test, "utf-8").trim(); // 看輸入的信息能否准確 System.out.println(strtest); } catch (UnsupportedEncodingException e) { // TODO Auto-generated catch block e.printStackTrace(); } } cursor.close(); } }
法式啟動時刻歸去檢討數據庫文件在不在,假如不存在,就會把我們預備好的數據庫復制到哪一個 databases 目次下,並且假如用戶卸載了這個法式,那末這個目次和數據庫也將隨之卸載。
再來一個示例。
正常的運用數據庫放在/data/data/包名/database/test.db,運用宣布時,這個數據庫不會跟著運用一路宣布,
所認為了讓我們曾經預備好的數據正常應用,必需能完成數據庫本身復制到sd卡上面,
完成拷貝res/raw/test.db下資本拷貝到SD卡下的/mnt/sdcard/test/test.db
代碼以下:
package zcping.syan.DBDefinition; import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import zcping.syan.DragonBaby.R; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.util.Log; public class ReleaseDataBaseActivity{ /** Called when the activity is first created. */ //SD卡下的目次 private final String DATABASE_PATH = android.os.Environment .getExternalStorageDirectory().getAbsolutePath() + "/db_exam"; //數據庫名 private final String DATABASE_FILENAME = "db_exam.db"; //這個context是必須的,沒有context,怎樣都不克不及完成數據庫的拷貝操作; private Context context; //結構函數必須傳入Context,數據庫的操作都帶有這個參數的傳入 public ReleaseDataBaseActivity(Context ctx) { this.context = ctx; } public SQLiteDatabase OpenDataBase() { try { String databaseFilename = DATABASE_PATH + "/" + DATABASE_FILENAME; File dir = new File(DATABASE_PATH); //斷定SD卡下能否存在寄存數據庫的目次,假如不存在,新建目次 if (!dir.exists()) { dir.mkdir(); Log.i("ReleaseDataBaseActivity", "dir made:" + DATABASE_PATH); } else { Log.i("ReleaseDataBaseActivity", "dir exist:" + DATABASE_PATH); } try { //假如數據庫曾經在SD卡的目次下存在,那末不須要從新創立,不然創立文件,並拷貝/res/raw上面的數據庫文件 if (!(new File(databaseFilename)).exists()) { Log.i("ReleaseDataBaseActivity", "file not exist:" + databaseFilename); ///res/raw數據庫作為輸入流 InputStream is = this.context.getResources().openRawResource( R.raw.db_exam); //測試用 int size = is.available(); Log.i( "ReleaseDataBaseActivity", "DATABASE_SIZE:" + 1 ); Log.i("ReleaseDataBaseActivity", "count:" + 0); //用於寄存數據庫信息的數據流 FileOutputStream fos = new FileOutputStream( databaseFilename); byte[] buffer = new byte[8192]; int count = 0; Log.i("ReleaseDataBaseActivity", "count:" + count); //把數據寫入SD卡目次下 while ((count = is.read(buffer)) > 0) { fos.write(buffer, 0, count); } fos.flush(); fos.close(); is.close(); } } catch (FileNotFoundException e) { Log.e("Database", "File not found"); e.printStackTrace(); } catch (IOException e) { Log.e("Database", "IO exception"); e.printStackTrace(); } //實例化sd卡上得數據庫,database作為前往值,是前面一切拔出,刪除,查詢操作的托言。 SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase( databaseFilename, null); return database; } catch (Exception e) { } return null; } }
經由測試,相對好使,願望對年夜家有贊助。