将assets目录下的数据库文件拷贝到当前应用程序下的files目录下
/**
* 将assets资产目录下的文件拷贝到系统目录下
*/
private void copyAssetsDB() {
final File file = new File(getFilesDir(),"address.db");//getFilesDir()方法用于获取/data/data//files目录
System.out.println("文件路径---->"+getFilesDir());
if(file.exists()){//文件存在了就不需要拷贝了
System.out.println("数据库文件已经存在,不需要再拷贝");
return;
}
new Thread(){
public void run() {
System.out.println("进行数据库文件拷贝");
try {
//获取资产目录管理器
AssetManager assetManager = getAssets();
InputStream is = assetManager.open("address.db");//输入流
FileOutputStream fos = new FileOutputStream(file);//输出流
byte[] buffer = new byte[1024];
int len = 0;
while((len=is.read(buffer))!=-1){
fos.write(buffer,0,len);
}
fos.close();
is.close();
} catch (Exception e) {
e.printStackTrace();
}
};
}.start();
}
加载数据库文件
/**
* 第一个参数:拷贝后的数据库路径
* 第二个参数:游标工厂
* 第三个参数:数据库访问模式
*/
SQLiteDatabase db = SQLiteDatabase.openDatabase(context.getFilesDir().getAbsolutePath()+"/address.db", null, SQLiteDatabase.OPEN_READONLY);