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

时间:2022-05-12 11:31:15 

其实很简单,就是把我们的数据库文件放到我们的手机里,所以不必局限在哪个地方写这个代码,在第一次创建数据库的时候可以,我觉得在软件起动页里效果更好一点,首先我们应该把事先写好的数据库文件比如 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;

/**
 * copy数据库到apk包
 *
 * @author NGJ
 *
 */
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/";
 }

 /**
  * 判断数据库是否存在
  *
  * @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;
 }

 /**
  * 复制数据库到手机指定文件夹下
  *
  * @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);// 得到数据库文件的写入流
  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");
  }


标签:Android,数据库,打包APK发布
0
投稿

猜你喜欢

  • spring boot如何指定启动端口

    2021-06-27 19:52:14
  • Spring Boot + Mybatis多数据源和动态数据源配置方法

    2023-02-16 17:15:31
  • Java、JavaScript、Oracle、MySQL中实现的MD5加密算法分享

    2022-08-24 02:42:11
  • Android标题栏中添加返回按钮功能

    2022-09-16 05:52:47
  • Android模块化中数据传递/路由跳转实现示例

    2023-06-29 03:12:06
  • Java基于ShardingSphere实现分库分表的实例详解

    2022-04-20 18:43:37
  • java switch语句使用注意的四大细节

    2022-07-10 10:46:04
  • Swing拆分窗格控件JSplitPane使用详解

    2022-11-14 21:13:48
  • java新人基础入门之递归调用

    2023-11-10 01:15:16
  • C#游戏开发之实现贪吃蛇游戏

    2023-01-28 01:48:48
  • 线程阻塞唤醒工具 LockSupport使用详解

    2023-11-29 17:16:10
  • Spring的Aware接口你知道多少

    2023-01-19 12:44:20
  • springboot使用事物注解方式代码实例

    2022-07-09 00:13:21
  • Feign如何自定义注解翻译器

    2022-11-09 07:05:04
  • 浅析依赖注入框架Autofac的使用

    2023-04-19 22:23:31
  • Java中Lambda表达式和函数式接口的使用和特性

    2023-06-20 20:05:42
  • Java中的双重检查(Double-Check)详解

    2023-02-23 21:05:23
  • 使用Logback设置property参数方式

    2022-07-28 01:06:01
  • Android 实现把bitmap图片的某一部分的颜色改成其他颜色

    2022-12-28 00:12:03
  • Java中GUI工具包AWT和Swing用法介绍

    2022-02-06 09:02:35
  • asp之家 软件编程 m.aspxhome.com