为什么手机安装apk后读取不到SQLite的数据
最近在学习Android,用的是eclipse开发环境,在虚拟机测试的时候没有一点问题,等把apk安装到手机上后,就读取不到sqlite数据库的数据了。
解决办法:将数据库与apk一起打包。首先把你的数据库文件复制到assets目录下,然后在主的Activity里面加如下面的代码
// 数据库的路径:/data/data/你的包名/databases/
String DB_PATH = "/data/data/com.gxuwz.food_shopping45/databases/";
// 数据库名字
String DB_NAME = "food_shoping45";
// 检查SQLite数据库文件是否存在
if((new File(DB_PATH+DB_NAME)).exists()==false) {
// 如 SQLite 数据库文件不存在,再检查一下 database 目录是否存在
File f=new File(DB_PATH);
// 如 database 目录不存在,新建该目录
if(!f.exists()) {
f.mkdir();
}
}
try {
// 得到 assets 目录下我们实现准备好的 SQLite 数据库作为输入流
InputStream is=getBaseContext().getAssets().open(DB_NAME);
// 输出流
OutputStream os=new FileOutputStream(DB_PATH+DB_NAME);
// 文件写入
byte[] buffer=new byte[1024];
int length;
while((length=is.read(buffer))>0) {
os.write(buffer, 0, length);
}
os.flush();
os.close();
is.close();
}catch (Exception e){
e.printStackTrace();
}