亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

Android應用開發之將SQLite和APK一起打包的方法

2019-11-26 15:00:41
字體:
來源:轉載
供稿:網友

在 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; }}

經過測試,絕對好使,希望對大家有幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久精品视频亚洲| 91精品国产一区| 久久久久99精品久久久久| 亚洲丝袜在线视频| 日韩精品极品毛片系列视频| 国产欧美日韩亚洲精品| 91精品国产91久久久久久不卡| 亚洲а∨天堂久久精品9966| 亚洲无限乱码一二三四麻| 国产成人精品视频在线| 日韩在线观看高清| 欧美天天综合色影久久精品| 人妖精品videosex性欧美| 久久亚洲精品成人| 最近2019免费中文字幕视频三| 欧美性猛交丰臀xxxxx网站| 欧美专区第一页| 夜夜躁日日躁狠狠久久88av| 欧美性生交xxxxxdddd| 性欧美暴力猛交69hd| 欧美日韩国产999| 久久躁日日躁aaaaxxxx| 久久大大胆人体| 欧美福利小视频| 久久精品人人做人人爽| 日本欧美黄网站| 精品久久在线播放| 2019国产精品自在线拍国产不卡| 日韩av在线电影网| 国产精品久久久久久久久免费| 亚洲视频自拍偷拍| 欧美激情2020午夜免费观看| 91在线视频一区| 精品中文字幕久久久久久| 亚洲图片在区色| 欧美激情乱人伦一区| 国产精品三级久久久久久电影| 久久天堂av综合合色| 国产日韩av在线| 亚洲高清色综合| 97久久精品在线| 91av在线国产| 成人免费在线视频网址| 97在线观看视频国产| 国产日韩综合一区二区性色av| 国产精品自拍小视频| 成人性教育视频在线观看| 色www亚洲国产张柏芝| 91社影院在线观看| 亚洲视频自拍偷拍| 欧美成人午夜激情视频| 国产精品日韩在线观看| 亚洲精品视频在线播放| 国产在线精品一区免费香蕉| 一区二区av在线| 日韩www在线| 亚洲xxxx3d| 亚洲福利在线视频| 国产精品亚洲网站| 日韩在线欧美在线国产在线| 日韩中文字幕在线| 欧美激情久久久久| 日韩精品在线免费观看| 欧美一级淫片videoshd| 成人福利视频在线观看| 日韩av在线精品| 亚洲精品日韩av| 性欧美在线看片a免费观看| 夜夜嗨av一区二区三区免费区| 亚洲一区二区日本| 国内精品国产三级国产在线专| 97超碰蝌蚪网人人做人人爽| 国产美女直播视频一区| 91免费国产视频| 丝袜美腿亚洲一区二区| 亚洲国产精品久久91精品| 8x海外华人永久免费日韩内陆视频| 97精品视频在线播放| 在线观看视频亚洲| 不卡av在线播放| 欧美激情精品久久久久久蜜臀| 色偷偷噜噜噜亚洲男人的天堂| 欧美激情手机在线视频| 美乳少妇欧美精品| 精品视频中文字幕| 亚洲а∨天堂久久精品喷水| 久久久久久久网站| 亚洲专区在线视频| 日韩成人性视频| 亚洲欧美一区二区三区在线| 色综合影院在线| 国产精品久久久91| 亚洲情综合五月天| 国产精品极品美女粉嫩高清在线| 亚洲国产欧美自拍| 亚洲欧美另类国产| 久久九九国产精品怡红院| 亚洲成人激情在线观看| 亚洲综合日韩在线| 中文字幕亚洲综合久久筱田步美| 亚洲福利在线观看| 亚洲一区第一页| 在线观看日韩专区| 国产视频久久久久| 国产成人av在线| 国产精品扒开腿做爽爽爽视频| 国内免费精品永久在线视频| 91人成网站www| 亚洲日本欧美日韩高观看| 国产精品久久久久久五月尺| 亚洲色图欧美制服丝袜另类第一页| 日韩av免费看| 国产精品免费小视频| 久久久久久久久久久亚洲| 久久久av网站| 久久91亚洲精品中文字幕奶水| 亚洲国产精品99| 亚洲久久久久久久久久久| 欧美黑人性生活视频| www.美女亚洲精品| 91久久国产精品| 7777免费精品视频| 亚洲免费成人av电影| 91高清视频免费| 91产国在线观看动作片喷水| 国产成人精品久久| 91国内精品久久| 亚洲v日韩v综合v精品v| 国产在线拍偷自揄拍精品| 91久久在线播放| 18一19gay欧美视频网站| 国产亚洲xxx| 国产精品夫妻激情| www国产91| 亚洲欧洲视频在线| 亚洲天堂av网| 中文字幕日韩在线观看| 2020国产精品视频| 青草热久免费精品视频| 日韩免费在线电影| 亚洲三级黄色在线观看| 国产日本欧美一区二区三区在线| 久久人人爽国产| 国产成人精品视| 欧美精品手机在线| 色av吧综合网| 亚洲精品视频免费| 亚洲成人精品久久| 91国产在线精品| 在线观看久久久久久| 日韩激情片免费| 日韩不卡在线观看| 亚洲图片欧美午夜| 亚洲精品国产精品国自产观看浪潮| 成人免费xxxxx在线观看| 亚洲成人av资源网| 欧美另类在线播放| 日韩国产欧美精品在线| 日韩免费电影在线观看| 91精品在线国产| 亚洲一区二区久久久久久久| 国产精品视频区1| 在线日韩日本国产亚洲| 久久夜色精品亚洲噜噜国产mv|