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;
}
}
經由測試,相對好使,願望對年夜家有贊助。