栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 移动开发 > Android

Android 数据库打包随APK发布的实例代码

Android 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Android 数据库打包随APK发布的实例代码

其实很简单,就是把我们的数据库文件放到我们的手机里,所以不必局限在哪个地方写这个代码,在第一次创建数据库的时候可以,我觉得在软件起动页里效果更好一点,首先我们应该把事先写好的数据库文件比如 test.db放到res文件夹里的raw文件夹里,也可以放到assets里,因为这两个文件夹不会在生成APK的时候不会被压缩。
1,DatabaseUtil用于将raw中的db文件copy到手机中,代码如下
复制代码 代码如下:
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;


public class DatabaseUtil {

 private Context context;
 public static String dbName = "Kao.db";// 数据库的名字
 private static String DATAbase_PATH;// 数据库在手机里的路径

 public DatabaseUtil(Context context) {
  this.context = context;
  String packageName = context.getPackageName();
  DATAbase_PATH="/data/data/"+packageName+"/databases/";
 }

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

 
 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);// 得到数据库文件的写入流
  InputStream is = context.getResources().openRawResource(R.raw.kao);// 得到数据库文件的数据流
  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); 
        // 判断数据库是否存在 
        boolean dbExist = util.checkDatabase(); 

        if (dbExist) { 
            Log.i("tag", "The database is exist."); 
        } else {// 不存在就把raw里的数据库写入手机 
            try { 
               util.copyDatabase(); 
           } catch (IOException e) { 
               thrownew Error("Error copying database"); 
           } 
        } 
    } 


3,检测是否有SDCard,执行copy。(个人感觉可以不检测SD卡是否存在,但不检测似乎有个问题,程序原因?)

复制代码 代码如下:
boolean hasSDCard = Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED);
  if(hasSDCard){
   copyDatabaseToPhone();
  }else{
   showToast("未检测到SDCard");
  }

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/164922.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号