您的位置:首页 > 数据库

在assets目录下存放本地数据库

2015-10-30 01:09 323 查看
对于一些来自本地的庞大数据库,如果还是依靠SQLiteOpenHelper再去创建数据库的话,太耗时耗力了。所以最常见的做法是:将数据库放在assets目录下,跟随apk一起发布出去。存放在该目录下的文件的特点:

1.assets里面存放的都是原生文件,不会对里面的文件转码

2.该目录下的文件只支持读取,即只能获取输入流

3.不在R文件注册

4.可以建文件夹

5.一般存放网页,图片,音乐,数据库,文本文件等:

但是一旦将数据库存储在此目录下,就不能访问该数据库了(因为数据库打不开了)。解决方案是:将数据库拷贝到手机本地目录(手机内存和外存都可以)。

拷贝数据库的最佳时间:项目初始化的时候,一般就是在展示公司Logo,检查版本更新的时候开始拷贝。并且,控制好只拷贝一次。所以在有数据库在assets目录下,需要拷贝的时候,可以新增如下代码,然后在onCreate中调用这个方法完成只拷贝一次:

// 从asserts目录下拷贝文件到files
private void copyDB() {

// 获取输出流,文件存储目录:data/data/包名/files目录下,文件名相同
File file = new File(getFilesDir(), "xxxxx.db");

// 当文件不存在的时候:才去拷贝,已经存在的不再去拷贝了。
if (!file.exists()) {
AssetManager assetManager = getAssets();

try {

// 获取输入流
InputStream is = assetManager.open("xxxxx.db");

FileOutputStream fos = new FileOutputStream(file);
// 开始读和写
byte[] bys = new byte[1024];
int len;
while ((len = is.read(bys)) != -1) {
fos.write(bys, 0, len);
}
is.close();
fos.close();

} catch (Exception e) {
e.printStackTrace();
}
}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  assets目录 数据库