欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android 數(shù)據(jù)庫(kù)打包隨APK發(fā)布的實(shí)例代碼

 更新時(shí)間:2013年10月02日 15:32:18   作者:  
有些時(shí)候我們的軟件用到SQLite數(shù)據(jù)庫(kù),這個(gè)時(shí)候怎么把一個(gè)做好的數(shù)據(jù)庫(kù)打包進(jìn)我們的APK呢

其實(shí)很簡(jiǎn)單,就是把我們的數(shù)據(jù)庫(kù)文件放到我們的手機(jī)里,所以不必局限在哪個(gè)地方寫這個(gè)代碼,在第一次創(chuàng)建數(shù)據(jù)庫(kù)的時(shí)候可以,我覺(jué)得在軟件起動(dòng)頁(yè)里效果更好一點(diǎn),首先我們應(yīng)該把事先寫好的數(shù)據(jù)庫(kù)文件比如 test.db放到res文件夾里的raw文件夾里,也可以放到assets里,因?yàn)檫@兩個(gè)文件夾不會(huì)在生成APK的時(shí)候不會(huì)被壓縮。
1,DataBaseUtil用于將raw中的db文件copy到手機(jī)中,代碼如下

復(fù)制代碼 代碼如下:

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數(shù)據(jù)庫(kù)到apk包
 *
 * @author NGJ
 *
 */
public class DataBaseUtil {

 private Context context;
 public static String dbName = "Kao.db";// 數(shù)據(jù)庫(kù)的名字
 private static String DATABASE_PATH;// 數(shù)據(jù)庫(kù)在手機(jī)里的路徑

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

 /**
  * 判斷數(shù)據(jù)庫(kù)是否存在
  *
  * @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;
 }

 /**
  * 復(fù)制數(shù)據(jù)庫(kù)到手機(jī)指定文件夾下
  *
  * @throws IOException
  */
 public void copyDataBase() throws IOException {
  String databaseFilenames = DATABASE_PATH + dbName;
  File dir = new File(DATABASE_PATH);
  if (!dir.exists())// 判斷文件夾是否存在,不存在就新建一個(gè)
   dir.mkdir();
  FileOutputStream os = new FileOutputStream(databaseFilenames);// 得到數(shù)據(jù)庫(kù)文件的寫入流
  InputStream is = context.getResources().openRawResource(R.raw.kao);// 得到數(shù)據(jù)庫(kù)文件的數(shù)據(jù)流
  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操作
復(fù)制代碼 代碼如下:

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

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


3,檢測(cè)是否有SDCard,執(zhí)行copy。(個(gè)人感覺(jué)可以不檢測(cè)SD卡是否存在,但不檢測(cè)似乎有個(gè)問(wèn)題,程序原因?)

復(fù)制代碼 代碼如下:

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

相關(guān)文章

最新評(píng)論