Android 數(shù)據(jù)庫打包隨APK發(fā)布的實(shí)例代碼
其實(shí)很簡單,就是把我們的數(shù)據(jù)庫文件放到我們的手機(jī)里,所以不必局限在哪個地方寫這個代碼,在第一次創(chuàng)建數(shù)據(jù)庫的時候可以,我覺得在軟件起動頁里效果更好一點(diǎn),首先我們應(yīng)該把事先寫好的數(shù)據(jù)庫文件比如 test.db放到res文件夾里的raw文件夾里,也可以放到assets里,因?yàn)檫@兩個文件夾不會在生成APK的時候不會被壓縮。
1,DataBaseUtil用于將raw中的db文件copy到手機(jī)中,代碼如下
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ù)庫到apk包
*
* @author NGJ
*
*/
public class DataBaseUtil {
private Context context;
public static String dbName = "Kao.db";// 數(shù)據(jù)庫的名字
private static String DATABASE_PATH;// 數(shù)據(jù)庫在手機(jī)里的路徑
public DataBaseUtil(Context context) {
this.context = context;
String packageName = context.getPackageName();
DATABASE_PATH="/data/data/"+packageName+"/databases/";
}
/**
* 判斷數(shù)據(jù)庫是否存在
*
* @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ù)庫到手機(jī)指定文件夾下
*
* @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);// 得到數(shù)據(jù)庫文件的寫入流
InputStream is = context.getResources().openRawResource(R.raw.kao);// 得到數(shù)據(jù)庫文件的數(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操作
Java代碼
privatevoid copyDataBaseToPhone() {
DataBaseUtil util = new DataBaseUtil(this);
// 判斷數(shù)據(jù)庫是否存在
boolean dbExist = util.checkDataBase();
if (dbExist) {
Log.i("tag", "The database is exist.");
} else {// 不存在就把raw里的數(shù)據(jù)庫寫入手機(jī)
try {
util.copyDataBase();
} catch (IOException e) {
thrownew Error("Error copying database");
}
}
}
3,檢測是否有SDCard,執(zhí)行copy。(個人感覺可以不檢測SD卡是否存在,但不檢測似乎有個問題,程序原因?)
boolean hasSDCard = Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED);
if(hasSDCard){
copyDataBaseToPhone();
}else{
showToast("未檢測到SDCard");
}
- Android SQLite數(shù)據(jù)庫版本升級的管理實(shí)現(xiàn)
- Android實(shí)現(xiàn)創(chuàng)建或升級數(shù)據(jù)庫時執(zhí)行語句
- Android SQLite數(shù)據(jù)庫增刪改查操作的使用詳解
- Android使用SQLite數(shù)據(jù)庫的簡單實(shí)例
- 條件數(shù)據(jù)庫Android:sqllite的簡單使用
- Android中操作SQLite數(shù)據(jù)庫快速入門教程
- Android創(chuàng)建和使用數(shù)據(jù)庫SQLIte
- Android SQLite數(shù)據(jù)庫增刪改查操作的案例分析
- Android操作SQLite數(shù)據(jù)庫(增、刪、改、查、分頁等)及ListView顯示數(shù)據(jù)的方法詳解
- Android開發(fā)中數(shù)據(jù)庫升級且表添加新列的方法
相關(guān)文章
Kotlin標(biāo)準(zhǔn)函數(shù)與靜態(tài)方法應(yīng)用詳解
Kotlin中的標(biāo)準(zhǔn)函數(shù)指的是Standard.kt文件中定義的函數(shù),任何Kotlin代碼都可以自由地調(diào)用所有的標(biāo)準(zhǔn)函數(shù)。例如let這個標(biāo)準(zhǔn)函數(shù),他的主要作用就是配合?.操作符來進(jìn)行輔助判空處理2022-12-12Android Socket服務(wù)端與客戶端用字符串的方式互相傳遞圖片的方法
這篇文章主要介紹了Android Socket服務(wù)端與客戶端用字符串的方式互相傳遞圖片的方法的相關(guān)資料,需要的朋友可以參考下2016-05-05Android 開發(fā)實(shí)現(xiàn)EditText 光標(biāo)居右顯示
這篇文章主要介紹了Android 開發(fā)實(shí)現(xiàn)EditText 光標(biāo)居右顯示的相關(guān)資料,需要的朋友可以參考下2017-02-02Android中WebChromeClient和WebViewClient的區(qū)別淺析
這篇文章主要介紹了Android中WebChromeClient和WebViewClient的區(qū)別淺析,需要的朋友可以參考下2015-04-04Android實(shí)現(xiàn)帶節(jié)點(diǎn)的進(jìn)度條
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)帶節(jié)點(diǎn)的進(jìn)度條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-03-03Android應(yīng)用APP自動更新功能的代碼實(shí)現(xiàn)
本篇文章主要介紹了Android應(yīng)用APP自動更新功能的代碼實(shí)現(xiàn),想要實(shí)現(xiàn)這個效果的同學(xué)可以了解一下。2016-11-11