a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 系統 > Android > 正文

Android 數據庫打包隨APK發布的實例代碼

2020-04-11 12:02:37
字體:
來源:轉載
供稿:網友

其實很簡單,就是把我們的數據庫文件放到我們的手機里,所以不必局限在哪個地方寫這個代碼,在第一次創建數據庫的時候可以,我覺得在軟件起動頁里效果更好一點,首先我們應該把事先寫好的數據庫文件比如 test.db放到res文件夾里的raw文件夾里,也可以放到assets里,因為這兩個文件夾不會在生成APK的時候不會被壓縮。
1,DataBaseUtil用于將raw中的db文件copy到手機中,代碼如下

復制代碼 代碼如下:

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;

import com.ata.app.R;

/**
 * copy數據庫到apk包
 *
 * @author NGJ
 *
 */
public class DataBaseUtil {

 private Context context;
 public static String dbName = "Kao.db";// 數據庫的名字
 private static String DATABASE_PATH;// 數據庫在手機里的路徑

 public DataBaseUtil(Context context) {
  this.context = context;
  String packageName = context.getPackageName();
  DATABASE_PATH="/data/data/"+packageName+"/databases/";
 }

 /**
  * 判斷數據庫是否存在
  *
  * @return false or true
  */
 public boolean checkDataBase() {
  SQLiteDatabase db = null;
  try {
   String databaseFilename = DATABASE_PATH + dbName;
   db = SQLiteDatabase.openDatabase(databaseFilename, null,SQLiteDatabase.OPEN_READONLY);
  } catch (SQLiteException e) {

  }
  if (db != null) {
   db.close();
  }
  return db != null ? true : false;
 }

 /**
  * 復制數據庫到手機指定文件夾下
  *
  * @throws IOException
  */
 public void copyDataBase() throws IOException {
  String databaseFilenames = DATABASE_PATH + dbName;
  File dir = new File(DATABASE_PATH);
  if (!dir.exists())// 判斷文件夾是否存在,不存在就新建一個
   dir.mkdir();
  FileOutputStream os = new FileOutputStream(databaseFilenames);// 得到數據庫文件的寫入流
  InputStream is = context.getResources().openRawResource(R.raw.kao);// 得到數據庫文件的數據流
  byte[] buffer = new byte[8192];
  int count = 0;
  while ((count = is.read(buffer)) > 0) {
   os.write(buffer, 0, count);
   os.flush();
  }
  is.close();
  os.close();
 }
}


2,在需要的activity中加入如下方法用于具體的copy操作
復制代碼 代碼如下:

Java代碼 
privatevoid copyDataBaseToPhone() { 
        DataBaseUtil util = new DataBaseUtil(this); 
        // 判斷數據庫是否存在 
        boolean dbExist = util.checkDataBase(); 

        if (dbExist) { 
            Log.i("tag", "The database is exist."); 
        } else {// 不存在就把raw里的數據庫寫入手機 
            try { 
               util.copyDataBase(); 
           } catch (IOException e) { 
               thrownew Error("Error copying database"); 
           } 
        } 
    } 


3,檢測是否有SDCard,執行copy。(個人感覺可以不檢測SD卡是否存在,但不檢測似乎有個問題,程序原因?)

復制代碼 代碼如下:

boolean hasSDCard = Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED);
  if(hasSDCard){
   copyDataBaseToPhone();
  }else{
   showToast("未檢測到SDCard");
  }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久亚洲精品中文字幕 | 国产成人午夜精品影院游乐网 | 国产美女中出 | 久久9久| www.国产高清 | 欧洲亚洲精品久久久久 | 中国av在线| 青草免费视频 | 国产精品一区二区欧美 | 日本一区二区精品 | 欧美日韩中文在线 | 久草视频在线播放 | 欧美日韩亚洲三区 | 日韩av激情在线观看 | 久久久久久久久99精品 | 在线高清av | 国产精品久久 | 91精品一区二区三区久久久久久 | 国产精品美女久久久久久久久久久 | 亚洲高清视频一区二区三区 | 亚洲黄色免费观看 | 久久婷婷国产麻豆91天堂 | 成人午夜在线 | 久久久久久久久久久久网站 | 日韩av一区二区三区在线 | 日韩中文字幕一区 | 精品国产乱码久久久久久影片 | 日韩性视频 | 色天天综合久久久久综合片 | 99精品久久久久久久免费 | 国产欧美日韩精品一区 | 成人激情视频在线播放 | aaa久久 | 男女羞羞视频在线观看 | 日韩一区二区黄色片 | 国产伦精品久久久一区二区三区 | 国产一区二区av | 亚洲国产午夜 | 欧美一区二区三区四区五区 | 男女羞羞视频在线观看免费 | 色性网|