在做Android应用的时候,不可避免要用到数据库。但是当我们把应用的apk部署到真机上的时候,已经创建好的数据库及其里边的数据是不能随着apk一起安装到真机上的。

(PS:这篇博客解决了我前面博客中写的一个小游戏的一个问题,另外也可以读取Raw目录下的数据库文件)

这就造成了一个问题,这个问题其实很好解决,解决方法如下:

我们首先把有数据的数据库文件放在assets资源目录下边,然后在apk应用启动的时候,把assets目录下的数据库文件的数据写入到真机的内存中去。

下边开始我们的代码编写:

首先,我们建立一个datab的Android Project命名为datab,我们把工程的目录视图贴出来:

我们首先要创建一个数据库,可以在DatabActivity.java中用sql语句创建,然后插入几条数据。然后把创建好并且插入数据的数据库放入assets文件夹下边。

我们看下我放入的test.db数据库的结构:

可以看到,在test.db中我们插入了三条数据。

接下来,我们就是要在应用启动的时候读取assets目录下的数据库,然后把test.db写入SDcard的data/data/com.datab.cn路径下边。

我们首先新建一个类:SQLdm.java:

  1. <span style="font-size:18px;">package com.datab.cn;
  2. import java.io.File;
  3. import java.io.FileOutputStream;
  4. import java.io.IOException;
  5. import java.io.InputStream;
  6. import android.content.Context;
  7. import android.content.res.AssetManager;
  8. import android.database.sqlite.SQLiteDatabase;
  9. import android.util.Log;
  10. /**
  11. * 这个类就是实现从assets目录读取数据库文件然后写入SDcard中,如果在SDcard中存在,就打开数据库,不存在就从assets目录下复制过去
  12. * @author Big_Adamapple
  13. *
  14. */
  15. public class SQLdm {
  16. //数据库存储路径
  17. String filePath = "data/data/com.datab.cn/test.db";
  18. //数据库存放的文件夹 data/data/com.main.jh 下面
  19. String pathStr = "data/data/com.datab.cn";
  20. SQLiteDatabase database;
  21. public  SQLiteDatabase openDatabase(Context context){
  22. System.out.println("filePath:"+filePath);
  23. File jhPath=new File(filePath);
  24. //查看数据库文件是否存在
  25. if(jhPath.exists()){
  26. Log.i("test", "存在数据库");
  27. //存在则直接返回打开的数据库
  28. return SQLiteDatabase.openOrCreateDatabase(jhPath, null);
  29. }else{
  30. //不存在先创建文件夹
  31. File path=new File(pathStr);
  32. Log.i("test", "pathStr="+path);
  33. if (path.mkdir()){
  34. Log.i("test", "创建成功");
  35. }else{
  36. Log.i("test", "创建失败");
  37. };
  38. try {
  39. //得到资源
  40. AssetManager am= context.getAssets();
  41. //得到数据库的输入流
  42. InputStream is=am.open("test.db");
  43. Log.i("test", is+"");
  44. //用输出流写到SDcard上面
  45. FileOutputStream fos=new FileOutputStream(jhPath);
  46. Log.i("test", "fos="+fos);
  47. Log.i("test", "jhPath="+jhPath);
  48. //创建byte数组  用于1KB写一次
  49. byte[] buffer=new byte[1024];
  50. int count = 0;
  51. while((count = is.read(buffer))>0){
  52. Log.i("test", "得到");
  53. fos.write(buffer,0,count);
  54. }
  55. //最后关闭就可以了
  56. fos.flush();
  57. fos.close();
  58. is.close();
  59. } catch (IOException e) {
  60. // TODO Auto-generated catch block
  61. e.printStackTrace();
  62. return null;
  63. }
  64. //如果没有这个数据库  我们已经把他写到SD卡上了,然后在执行一次这个方法 就可以返回数据库了
  65. return openDatabase(context);
  66. }
  67. }
  68. }
  69. </span>

然后,我们在DatabActivity.java中获得数据库中的数据:

  1. <span style="font-size:18px;">package com.datab.cn;
  2. import android.app.Activity;
  3. import android.database.Cursor;
  4. import android.database.sqlite.SQLiteDatabase;
  5. import android.os.Bundle;
  6. import android.widget.TextView;
  7. public class DatabActivity extends Activity {
  8. /** Called when the activity is first created. */
  9. @Override
  10. public void onCreate(Bundle savedInstanceState) {
  11. super.onCreate(savedInstanceState);
  12. setContentView(R.layout.main);
  13. //打开数据库输出流
  14. SQLdm s = new SQLdm();
  15. SQLiteDatabase db =s.openDatabase(getApplicationContext());
  16. TextView textv = (TextView) findViewById(R.id.textv);
  17. //查询数据库中testid=1的数据
  18. Cursor cursor = db.rawQuery("select * from testbiao where testid=?", new String[]{"1"});
  19. String name = null;
  20. if(cursor.moveToFirst()){
  21. name = cursor.getString(cursor.getColumnIndex("name"));
  22. }
  23. //这是一个TextView,把得到的数据库中的name显示出来.
  24. textv.setText(name);
  25. cursor.close();
  26. }
  27. }</span>

我们的main.xml视图也贴出来吧,很简单,一看就懂了。

然后,我们在虚拟机上看看我们的界面是什么样的:

可以看到,我们得到了数据库中的数据了,接下来大家可以把bin目录下的apk文件放入到真机中测试,依然会得到数据库中的数据

[转]读取assets目录下的数据库文件的更多相关文章

  1. Android读取assets目录下的资源

    1.获取资源的输入流 资源文件 sample.txt 位于 $PROJECT_HOME/assets/ 目录下,可以在 Activity 中通过 Context.getAssets().open(“s ...

  2. 【Unity基础知识之三】Unity Assets目录下的特殊文件夹名称

    Unity3D的特殊目录名称   Unity预留了一些目录名称,这些目录有着特殊的含义.比较重要的有: Resources这个目录下的所有文件都会被打包到发布版本中,程序可以通过文件路径来访问它们.这 ...

  3. Python读取指定目录下指定后缀文件并保存为docx

    最近有个奇葩要求 要项目中的N行代码 申请专利啥的 然后作为程序员当然不能复制粘贴 用代码解决.. 使用python-docx读写docx文件 环境使用python3.6.0 首先pip安装pytho ...

  4. 遍历并读取指定目录下的所有文件内容,写入Map集合然后输出在控制台和本地文件

    public class FileWrite { public static void main(String[] args) throws Exception { //封装数据源目录 File sr ...

  5. Python读取一个目录下的所有文件

    #!/usr/bin/python # -*- coding:utf8 -*- import os allFileNum = 0 def printPath(level, path): global ...

  6. Spark:java api读取hdfs目录下多个文件

    需求: 由于一个大文件,在spark中加载性能比较差.于是把一个大文件拆分为多个小文件后上传到hdfs,然而在spark2.2下如何加载某个目录下多个文件呢? public class SparkJo ...

  7. WebApp基础01-设置读取assets目录下文件

    要读取assets下的目录,只需要修改三个地方即可 1.res/layout/activity_main.xml 2.AndroidManifest.xml 3.src\com\example\lcy ...

  8. Unity Assets目录下的特殊文件夹名称

    1.隐藏文件夹以.开头的文件夹会被Unity忽略.在这种文件夹中的资源不会被导入,脚本不会被编译.也不会出现在Project视图中.2.Standard Assets在这个文件夹中的脚本最先被编译.这 ...

  9. (转)Unity Assets目录下的特殊文件夹名称(作用和是否会被打包到build中)

    原文:http://wiki.unity3d.com/index.php/Special_Folder_Names_in_your_Assets_Folder 1.隐藏文件夹以.开头的文件夹会被Uni ...

随机推荐

  1. html 框架属性

    <html>    <head>        <title></title>    </head>    <frameset col ...

  2. hdu_5742_It's All In The Mind

    题目链接:hdu_5742_It's All In The Mind 题意: 有一个部分的数列,让你找一个满足他给的三个条件的数列,使前两个数的和除这个数列的sum最大 题解: xjb贪心一下就行了. ...

  3. ACboy needs your help again!

    ACboy needs your help again! Time Limit : 1000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Ja ...

  4. R语言笔记3--实例1

    综合性例子: 模拟产生统计专业同学的名单(学号区分),记录数学分析,线性代数.概率统计三科成绩,然后进行一些统计分析 1.首先产生一个向量(100个元素,代表100位学生) 2.模拟成绩 runif: ...

  5. weka对数据进行预测

    1.注意待预测数据集和训练用数据集各个属性的设置必须是一致的.即使你没有待预测数据集的Class属性的值,你也要添加这个属性,可以将该属性在各实例上的值均设成缺失值.比如你可以将欲预测的类别设为?即缺 ...

  6. AngularJS 的表单验证

    最近开始学习angularjs,学到表单验证的时候发现有必要学习下大神的好文章: 转:http://www.oschina.net/translate/angularjs-form-validatio ...

  7. css:cdata

    javascript <![CDATA[的web标准使用方法   根据W3C XHTML 1.0的规定:在XHTML中,因为<和&这两个符号有特殊意义(小于号用于标签的开始标记), ...

  8. CSS box-flex属性

    http://www.zhangxinxu.com/wordpress/2010/12/css-box-flex属性,然后弹性盒子模型简介/ http://www.zhangxinxu.com/wor ...

  9. swfupload在chrome中点击上传图片按钮无反应的解决办法

    chrome 22.0.XXXXX dev版上传图片按钮点击无反应原因:是GOOGLE的内建Flash PPAPI外挂所导致的. 问题原因: 由于Google浏览器(Chrome),在最新测试版22. ...

  10. boost ASIO实例

    client端代码 #include <iostream> #include <boost/asio.hpp> #include <boost/bind.hpp> ...