[转]读取assets目录下的数据库文件
在做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:
- <span style="font-size:18px;">package com.datab.cn;
- import java.io.File;
- import java.io.FileOutputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import android.content.Context;
- import android.content.res.AssetManager;
- import android.database.sqlite.SQLiteDatabase;
- import android.util.Log;
- /**
- * 这个类就是实现从assets目录读取数据库文件然后写入SDcard中,如果在SDcard中存在,就打开数据库,不存在就从assets目录下复制过去
- * @author Big_Adamapple
- *
- */
- public class SQLdm {
- //数据库存储路径
- String filePath = "data/data/com.datab.cn/test.db";
- //数据库存放的文件夹 data/data/com.main.jh 下面
- String pathStr = "data/data/com.datab.cn";
- SQLiteDatabase database;
- public SQLiteDatabase openDatabase(Context context){
- System.out.println("filePath:"+filePath);
- File jhPath=new File(filePath);
- //查看数据库文件是否存在
- if(jhPath.exists()){
- Log.i("test", "存在数据库");
- //存在则直接返回打开的数据库
- return SQLiteDatabase.openOrCreateDatabase(jhPath, null);
- }else{
- //不存在先创建文件夹
- File path=new File(pathStr);
- Log.i("test", "pathStr="+path);
- if (path.mkdir()){
- Log.i("test", "创建成功");
- }else{
- Log.i("test", "创建失败");
- };
- try {
- //得到资源
- AssetManager am= context.getAssets();
- //得到数据库的输入流
- InputStream is=am.open("test.db");
- Log.i("test", is+"");
- //用输出流写到SDcard上面
- FileOutputStream fos=new FileOutputStream(jhPath);
- Log.i("test", "fos="+fos);
- Log.i("test", "jhPath="+jhPath);
- //创建byte数组 用于1KB写一次
- byte[] buffer=new byte[1024];
- int count = 0;
- while((count = is.read(buffer))>0){
- Log.i("test", "得到");
- fos.write(buffer,0,count);
- }
- //最后关闭就可以了
- fos.flush();
- fos.close();
- is.close();
- } catch (IOException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- return null;
- }
- //如果没有这个数据库 我们已经把他写到SD卡上了,然后在执行一次这个方法 就可以返回数据库了
- return openDatabase(context);
- }
- }
- }
- </span>
然后,我们在DatabActivity.java中获得数据库中的数据:
- <span style="font-size:18px;">package com.datab.cn;
- import android.app.Activity;
- import android.database.Cursor;
- import android.database.sqlite.SQLiteDatabase;
- import android.os.Bundle;
- import android.widget.TextView;
- public class DatabActivity extends Activity {
- /** Called when the activity is first created. */
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- //打开数据库输出流
- SQLdm s = new SQLdm();
- SQLiteDatabase db =s.openDatabase(getApplicationContext());
- TextView textv = (TextView) findViewById(R.id.textv);
- //查询数据库中testid=1的数据
- Cursor cursor = db.rawQuery("select * from testbiao where testid=?", new String[]{"1"});
- String name = null;
- if(cursor.moveToFirst()){
- name = cursor.getString(cursor.getColumnIndex("name"));
- }
- //这是一个TextView,把得到的数据库中的name显示出来.
- textv.setText(name);
- cursor.close();
- }
- }</span>
我们的main.xml视图也贴出来吧,很简单,一看就懂了。
然后,我们在虚拟机上看看我们的界面是什么样的:
可以看到,我们得到了数据库中的数据了,接下来大家可以把bin目录下的apk文件放入到真机中测试,依然会得到数据库中的数据
[转]读取assets目录下的数据库文件的更多相关文章
- Android读取assets目录下的资源
1.获取资源的输入流 资源文件 sample.txt 位于 $PROJECT_HOME/assets/ 目录下,可以在 Activity 中通过 Context.getAssets().open(“s ...
- 【Unity基础知识之三】Unity Assets目录下的特殊文件夹名称
Unity3D的特殊目录名称 Unity预留了一些目录名称,这些目录有着特殊的含义.比较重要的有: Resources这个目录下的所有文件都会被打包到发布版本中,程序可以通过文件路径来访问它们.这 ...
- Python读取指定目录下指定后缀文件并保存为docx
最近有个奇葩要求 要项目中的N行代码 申请专利啥的 然后作为程序员当然不能复制粘贴 用代码解决.. 使用python-docx读写docx文件 环境使用python3.6.0 首先pip安装pytho ...
- 遍历并读取指定目录下的所有文件内容,写入Map集合然后输出在控制台和本地文件
public class FileWrite { public static void main(String[] args) throws Exception { //封装数据源目录 File sr ...
- Python读取一个目录下的所有文件
#!/usr/bin/python # -*- coding:utf8 -*- import os allFileNum = 0 def printPath(level, path): global ...
- Spark:java api读取hdfs目录下多个文件
需求: 由于一个大文件,在spark中加载性能比较差.于是把一个大文件拆分为多个小文件后上传到hdfs,然而在spark2.2下如何加载某个目录下多个文件呢? public class SparkJo ...
- WebApp基础01-设置读取assets目录下文件
要读取assets下的目录,只需要修改三个地方即可 1.res/layout/activity_main.xml 2.AndroidManifest.xml 3.src\com\example\lcy ...
- Unity Assets目录下的特殊文件夹名称
1.隐藏文件夹以.开头的文件夹会被Unity忽略.在这种文件夹中的资源不会被导入,脚本不会被编译.也不会出现在Project视图中.2.Standard Assets在这个文件夹中的脚本最先被编译.这 ...
- (转)Unity Assets目录下的特殊文件夹名称(作用和是否会被打包到build中)
原文:http://wiki.unity3d.com/index.php/Special_Folder_Names_in_your_Assets_Folder 1.隐藏文件夹以.开头的文件夹会被Uni ...
随机推荐
- iosUISegmentedControl的基本设置
//创建segmentControl 分段控件 UISegmentedControl *segC = [[UISegmentedControl alloc]initWithFrame:CGRectMa ...
- git基本命令--远程
git clone: # clone到 <本地目录名> $ git clone <版本库的网址> <本地目录名> # 克隆版本库的时候,所使用的远程主机自动被Git ...
- 再谈KMP
昨天讲解了字典树和AC自动机后感觉整个人都蒙掉了.还好就是自己今天在网上看见一篇对KMP讲解非常详细的帖子,果断收藏.(点击这里查看) 然后代码的实现也就简单分析一些了,具体的知识点大家直接自己链接过 ...
- JPG、PNG和GIF图片的基本原理及优化方法
一提到图片,我们就不得不从位图开始说起,位图图像(bitmap),也称为点阵图像或绘制图像,是由称作像素(图片元素)的单个点组成的.这些点可以进行不同的排列和染色以构成一副图片.当放大位图时,可以看见 ...
- DLT(Diagnostic Log and Trace)嵌入式系统程序运行记录
http://blog.csdn.net/yanlinembed/article/details/49837975 DLT的使用有属于Application范畴与Context范畴.在使用DLT时,需 ...
- jquery 高亮
<ul> <li id="0">冬瓜很好吃</li> <li id="1">西瓜不好吃</li> & ...
- 1*Json对象声明简单,复合,对象数组
//简单JSON对象 function btn1_click() { var json = { "id": 1001, "name": "张三&quo ...
- js中Object.__proto__===Function.prototype
参考:http://stackoverflow.com/questions/650764/how-does-proto-differ-from-constructor-prototype http:/ ...
- 3个同一行div的摆放div
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- opencv---cvor
void cvXor计算两个数组中的每个元素的按位异或. void cvXor (const CvArr* src1, const CvArr* src2, CvArr* dst, const CvA ...