热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

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

有些时候我们的软件用到SQLite数据库,这个时候怎么把一个做好的数据库打包进我们的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;

/**
 * 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应用开发过程中,开发者经常遇到诸如CPU使用率过高、内存泄漏等问题。本文将介绍几种常用的命令及其应用场景,帮助开发者有效定位并解决问题。 ... [详细]
  • 本文介绍了如何通过安装 sqlacodegen 和 pymysql 来根据现有的 MySQL 数据库自动生成 ORM 的模型文件(model.py)。此方法适用于需要快速搭建项目模型层的情况。 ... [详细]
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
  • JUnit下的测试和suite
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • Android 中的布局方式之线性布局
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 本文介绍了一种使用SQL Server存储过程来实现基于单一条件的高效分页查询的方法。通过示例代码,详细说明了如何构建和执行这种分页查询。 ... [详细]
  • CRZ.im:一款极简的网址缩短服务及其安装指南
    本文介绍了一款名为CRZ.im的极简网址缩短服务,该服务采用PHP和SQLite开发,体积小巧,约10KB。本文还提供了详细的安装步骤,包括环境配置、域名解析及Nginx伪静态设置。 ... [详细]
  • 探讨了SQL Server 2000自带工具绘制的一对多关系表的效果及其导出功能,并推荐了几款专业的ER图绘制软件。 ... [详细]
  • 如何将955万数据表的17秒SQL查询优化至300毫秒
    本文详细介绍了通过优化SQL查询策略,成功将一张包含955万条记录的财务流水表的查询时间从17秒缩短至300毫秒的方法。文章不仅提供了具体的SQL优化技巧,还深入探讨了背后的数据库原理。 ... [详细]
  • CentOS下ProFTPD的安装与配置指南
    本文详细介绍在CentOS操作系统上安装和配置ProFTPD服务的方法,包括基本配置、安全设置及高级功能的启用。 ... [详细]
  • 解决JavaScript中法语字符排序问题
    在开发一个使用JavaScript、HTML和CSS的Web应用时,遇到从SQLite数据库中提取的法语词汇排序不正确的问题,特别是带重音符号的字母未按预期排序。 ... [详细]
  • 本文详细介绍了PostgreSQL与MySQL在SQL语法上的主要区别,包括如何使用COALESCE替代IFNULL、金额格式化的方法、别名处理以及日期处理等关键点。 ... [详细]
  • 本文详细介绍了在 Ubuntu 16.04 系统上安装和配置 PostgreSQL 数据库的方法,包括如何设置监听地址、启用密码加密、更改默认用户密码以及调整客户端访问控制。 ... [详细]
  • 本文作为《WM平台上使用Sybase Anywhere 11》系列的第二篇,将继续探讨在Windows Mobile (WM) 系统中如何高效地操作Sybase Anywhere 11数据库。继上一篇关于安装与基本测试的文章之后,本篇将深入讲解数据库的具体操作方法。 ... [详细]
  • 本文探讨了在SQL Server中处理几何类型列时遇到的INTERSECT操作限制,并提供了解决方案,包括通过转换数据类型和使用额外表结构的方法。 ... [详细]
author-avatar
fangxiaoping47
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有