一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - Android應用開發之將SQLite和APK一起打包的方法

Android應用開發之將SQLite和APK一起打包的方法

2020-01-03 14:45libuchao JAVA教程

這篇文章主要介紹了Android應用開發之將SQLite和APK一起打包的方法,文章時間較早,盡管現在開發環境已大都遷移至Android Studio上,但打包原理依然相同,需要的朋友可以參考下

在 Eclipse 里新建好工程后,默認會有一個assets目錄,在 Eclipse 中直接將準備好的 SQLite 數據庫復制到該目錄中,然后在主 Activity 里面編碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
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

代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
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;
 }
}

經過測試,絕對好使,希望對大家有幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 4455在线 | 精品9e精品视频在线观看 | 金牛网155755水心论坛黄大父母 | 五月天婷婷精品免费视频 | 亚洲色图丝袜 | 18国产精品白浆在线观看免费 | 韩国久久| 和日本免费不卡在线v | 无遮无挡免费视频 | 男人躁女人p | 色综色| 91高清国产经典在线观看 | 国产成人综合久久精品红 | 亚洲国产成人精品无码区APP | 青草视频在线观看免费视频 | 韩国女主播在线大尺无遮挡 | 青青青国产手机在线播放 | 欧美美女一区二区三区 | 天堂69亚洲精品中文字幕 | 国内精品久久久久久不卡影院 | 免费看的毛片 | 91视频综合网 | 91国语精品自产拍在线观看一 | 成人毛片1024你懂的 | 亚洲一区二区三区不卡在线播放 | 双性np玩烂了np欲之国的太子 | 亚洲国产精品久久人人爱 | 国产欧美综合一区二区 | 日本高免费观看在线播放 | aaa毛片手机在线现看 | 男人女人性生活视频 | 日韩一级在线观看 | 亚洲精品视频在线免费 | 九九热在线视频 | 秋霞啪啪网 | 91会员 | 国产精品永久免费视频观看 | 草莓社区| 亚洲精品成人A8198A片漫画 | 国产欧美视频在线观看 | 天天狠天天天天透在线 |