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

Android應(yīng)用開發(fā)之將SQLite和APK一起打包的方法

 更新時間:2015年08月13日 15:19:32   作者:libuchao  
這篇文章主要介紹了Android應(yīng)用開發(fā)之將SQLite和APK一起打包的方法,文章時間較早,盡管現(xiàn)在開發(fā)環(huán)境已大都遷移至Android Studio上,但打包原理依然相同,需要的朋友可以參考下

在 Eclipse 里新建好工程后,默認(rèn)會有一個assets目錄,在 Eclipse 中直接將準(zhǔn)備好的 SQLite 數(shù)據(jù)庫復(fù)制到該目錄中,然后在主 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 是程序的包名,請根據(jù)自己的程序調(diào)整
 // /data/data/com.test.db/
 // databases 目錄是準(zhǔn)備放 SQLite 數(shù)據(jù)庫的地方,也是 Android 程序默認(rèn)的數(shù)據(jù)庫存儲目錄
 // 數(shù)據(jù)庫名為 test.db
 String DB_PATH = "/data/data/com.test.db/databases/";
 String DB_NAME = "test.db";

 // 檢查 SQLite 數(shù)據(jù)庫文件是否存在
 if ((new File(DB_PATH + DB_NAME)).exists() == false) {
  // 如 SQLite 數(shù)據(jù)庫文件不存在,再檢查一下 database 目錄是否存在
  File f = new File(DB_PATH);
  // 如 database 目錄不存在,新建該目錄
  if (!f.exists()) {
  f.mkdir();
  }

  try {
  // 得到 assets 目錄下我們實現(xiàn)準(zhǔn)備好的 SQLite 數(shù)據(jù)庫作為輸入流
  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);
  }

  // 關(guān)閉文件流
  os.flush();
  os.close();
  is.close();
  } catch (Exception e) {
  e.printStackTrace();
  }
 }

 // 下面測試 /data/data/com.test.db/databases/ 下的數(shù)據(jù)庫是否能正常工作
 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();
 }
}

程序啟動時候回去檢查數(shù)據(jù)庫文件在不在,如果不存在,就會把我們準(zhǔn)備好的數(shù)據(jù)庫復(fù)制到哪個 databases 目錄下,而且如果用戶卸載了這個程序,那么這個目錄和數(shù)據(jù)庫也將隨之卸載。

再來一個示例。
正常的應(yīng)用數(shù)據(jù)庫放在/data/data/包名/database/test.db,應(yīng)用發(fā)布時,這個數(shù)據(jù)庫不會隨著應(yīng)用一起發(fā)布,

所以為了讓我們已經(jīng)準(zhǔn)備好的數(shù)據(jù)正常使用,必須能實現(xiàn)數(shù)據(jù)庫自身復(fù)制到sd卡下面,

實現(xiàn)拷貝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";
 //數(shù)據(jù)庫名
 private final String DATABASE_FILENAME = "db_exam.db";
 //這個context是必需的,沒有context,怎么都不能實現(xiàn)數(shù)據(jù)庫的拷貝操作;
 private Context context;
 //構(gòu)造函數(shù)必需傳入Context,數(shù)據(jù)庫的操作都帶有這個參數(shù)的傳入
 public ReleaseDataBaseActivity(Context ctx) {
 this.context = ctx;
 }

 public SQLiteDatabase OpenDataBase() {
 try {
  String databaseFilename = DATABASE_PATH + "/" + DATABASE_FILENAME;
  File dir = new File(DATABASE_PATH);
  //判斷SD卡下是否存在存放數(shù)據(jù)庫的目錄,如果不存在,新建目錄
  if (!dir.exists()) {
  dir.mkdir();
  Log.i("ReleaseDataBaseActivity", "dir made:" + DATABASE_PATH);
  } else {
  Log.i("ReleaseDataBaseActivity", "dir exist:" + DATABASE_PATH);
  }
  try {
  //如果數(shù)據(jù)庫已經(jīng)在SD卡的目錄下存在,那么不需要重新創(chuàng)建,否則創(chuàng)建文件,并拷貝/res/raw下面的數(shù)據(jù)庫文件
  if (!(new File(databaseFilename)).exists()) {
   Log.i("ReleaseDataBaseActivity", "file not exist:"
    + databaseFilename);
   ///res/raw數(shù)據(jù)庫作為輸出流
   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);
   //用于存放數(shù)據(jù)庫信息的數(shù)據(jù)流
   FileOutputStream fos = new FileOutputStream(
    databaseFilename);
    byte[] buffer = new byte[8192];
   int count = 0;
   Log.i("ReleaseDataBaseActivity", "count:" + count);
   //把數(shù)據(jù)寫入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卡上得數(shù)據(jù)庫,database作為返回值,是后面所有插入,刪除,查詢操作的借口。
  SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(
   databaseFilename, null);
  return database;

 } catch (Exception e) {
 }
 return null;
 }
}

經(jīng)過測試,絕對好使,希望對大家有幫助。

相關(guān)文章

  • Java源碼解析HashMap成員變量

    Java源碼解析HashMap成員變量

    今天小編就為大家分享一篇關(guān)于Java源碼解析HashMap成員變量,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • java中關(guān)于深拷貝的幾種方式總結(jié)

    java中關(guān)于深拷貝的幾種方式總結(jié)

    這篇文章主要介紹了java中關(guān)于深拷貝的幾種方式總結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Spring IOC創(chuàng)建對象的兩種方式

    Spring IOC創(chuàng)建對象的兩種方式

    這篇文章主要給大家介紹了關(guān)于Spring IOC創(chuàng)建對象的兩種方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Java中二叉樹的先序、中序、后序遍歷以及代碼實現(xiàn)

    Java中二叉樹的先序、中序、后序遍歷以及代碼實現(xiàn)

    這篇文章主要介紹了Java中二叉樹的先序、中序、后序遍歷以及代碼實現(xiàn),一棵二叉樹是結(jié)點的一個有限集合,該集合或者為空,或者是由一個根節(jié)點加上兩棵別稱為左子樹和右子樹的二叉樹組成,需要的朋友可以參考下
    2023-11-11
  • SSH框架網(wǎng)上商城項目第1戰(zhàn)之整合Struts2、Hibernate4.3和Spring4.2

    SSH框架網(wǎng)上商城項目第1戰(zhàn)之整合Struts2、Hibernate4.3和Spring4.2

    SSH框架網(wǎng)上商城項目第1戰(zhàn)之整合Struts2、Hibernate4.3和Spring4.2,感興趣的小伙伴們可以參考一下
    2016-05-05
  • JAVA隨機打亂數(shù)組順序的方法

    JAVA隨機打亂數(shù)組順序的方法

    這篇文章主要介紹了JAVA隨機打亂數(shù)組順序的方法,包含了隨機數(shù)的應(yīng)用及數(shù)組的排序等操作,是Java操作數(shù)組的典型應(yīng)用,需要的朋友可以參考下
    2014-11-11
  • Java基于虹軟實現(xiàn)人臉識別、人臉比對、活性檢測等

    Java基于虹軟實現(xiàn)人臉識別、人臉比對、活性檢測等

    本文主要介紹了Java基于虹軟實現(xiàn)人臉識別、人臉比對、活性檢測等,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • 解析Java中的Field類和Method類

    解析Java中的Field類和Method類

    這篇文章主要介紹了Java中的Field類和Method類,是Java入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-12-12
  • Struts2源碼分析之ParametersInterceptor攔截器

    Struts2源碼分析之ParametersInterceptor攔截器

    這篇文章主要介紹了Struts2源碼分析之ParametersInterceptor攔截器,ParametersInterceptor攔截器其主要功能是把ActionContext中的請求參數(shù)設(shè)置到ValueStack中,,需要的朋友可以參考下
    2019-06-06
  • Java事件處理機制和適配器全面解析

    Java事件處理機制和適配器全面解析

    這篇文章主要介紹了Java事件處理機制和適配器全面解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12

最新評論