程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Android運用開辟之將SQLite和APK一路打包的辦法

Android運用開辟之將SQLite和APK一路打包的辦法

編輯:關於JAVA

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;
 }
}

經由測試,相對好使,願望對年夜家有贊助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved