Android开发系列(十七):读取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文件放入到真机中测试,依然会得到数据库中的数据

时间: 2024-12-26 22:06:24

Android开发系列(十七):读取assets目录下的数据库文件的相关文章

Android读取assets目录下的资源

1.获取资源的输入流 资源文件 sample.txt 位于 $PROJECT_HOME/assets/ 目录下,可以在 Activity 中通过 Context.getAssets().open(“sample.txt”) 方法获取输入流. 注意:如果资源文件是文本文件则需要考虑文件的编码和换行符.建议使用UTF-8和Unix换行符. 2. WebView 加载assets目录下的html文件 资源文件 sample.html 位于 $PROJECT_HOME/assets/ 目录下,可以通过以

Java API 读取HDFS目录下的所有文件

/** * 获取1号店生鲜食品的分类id字符串 * @param filePath * @return */ public String getYHDSXCategoryIdStr(String filePath) { final String DELIMITER = new String(new byte[]{1}); final String INNER_DELIMITER = ","; // 遍历目录下的所有文件 BufferedReader br = null; try { F

Java读取指定目录下的所有文件(子目录里的文件也可递归得到)

1 import java.io.File; 2 3 public class ReadFile { 4 5 public static void main(String[] args) { 6 7 // path是指定目录的绝对路径 8 String path = "/Users/tonychan/Workspaces/MyEclipse 2017 CI/Zhangjiajie/WebRoot/pics"; 9 getFile(path); 10 11 } 12 13 // 给定目录

(转)Unity Assets目录下的特殊文件夹名称

原文:http://wiki.unity3d.com/index.php/Special_Folder_Names_in_your_Assets_Folder 1.隐藏文件夹以.开头的文件夹会被Unity忽略.在这种文件夹中的资源不会被导入,脚本不会被编译.也不会出现在Project视图中.2.Standard Assets在这个文件夹中的脚本最先被编译.这个文件夹中的脚本会被导出到Assembly-CSharp-firstpass, Assembly-UnityScript-firstpass

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

1.隐藏文件夹 以.开头的文件夹会被Unity忽略.在这种文件夹中的资源不会被导入,脚本不会被编译.也不会出现在Project视图中.2.Standard Assets 在这个文件夹中的脚本最先被编译. 这个文件夹中的脚本会被导出到Assembly-CSharp-firstpass, Assembly-UnityScript-firstpass 或 Assembly-Boo-firstpass项目中,依语言而定.参考http://docs.unity3d.com/Documentation/Ma

读取指定目录下的所有文件(windows 和 linux 版)

笔者这里用到了OpenCV,如果不需要用OpenCV代码的话,可以将这部分代码去掉即可. windows  vs2015环境代码如下: #include <io.h> // 结构体struct _finddata_t需要用到 #include <opencv2/opencv.hpp> using namespace cv; using namespace std; char * fileLoadPath = "E:\\ubshare\\Cars\\102051724100

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

1.res/layout/activity_main.xml加入代码,需要在xml布局文件中声明WebView组件 <WebView android:id="@+id/webview" android:layout_width="fill_parent" android:layout_height="fill_parent" /> 2.在Activity中实例化WebView,并且可通过loadUrl(url)方法打开指定url资源

shell 读取某个目录下的所有文件

#!/bin/shFILE_PATH=“xxx” xxx:路径cd $FILE_PATHfor FILE in `ls` do echo $FILE done

Android开发之assets目录下资源使用总结

预前知识: Android资源文件分类: Android资源文件大致可以分为两种: 第一种是res目录下存放的可编译的资源文件: 这种资源文件系统会在R.java里面自动生成该资源文件的ID,所以访问这种资源文件比较简单,通过R.XXX.ID即可: 第二种是assets目录下存放的原生资源文件: 因为系统在编译的时候不会编译assets下的资源文件,所以我们不能通过R.XXX.ID的方式访问它们.那我么能不能通过该资源的绝对路径去访问它们呢?因为apk安装之后会放在/data/app/**.ap