之前提出的要求如下:
自己写个APK,安装在android手机,程序运行时会创建一个SQLITE的数据库;
用eclipse,可以看到数据库的位置,我把手机插入电脑,打USB连接后,却不能在手机中找到数据库文件(APK绝对是安装在SD卡上的),有人说要有ROOT的权限。不知如何实现,如果要写一个程序来实现,请高手指点思想,列出相关重点函数,谢谢
rover11大神的回答如下:
自己的应用复制自己的数据库,无需root,直接文件复制就行,大概如下:
File f = new File("/data/data/应用的包名/databases/数据库名"); //比如 "/data/data/com.hello/databases/test.db"
String sdcardPath = Environment.getExternalStorageDirectory().getAbsolutePath();
File o = new File(sdcardPath+"cp.db"); //sdcard上的目标地址
if(f.exists()) {
FileChannel outF;
try {
outF = new FileOutputStream(o).getChannel();
new FileInputStream(f).getChannel().transferTo(0, f.length(),outF);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
Toast.makeText(mainpage.this, "完成", Toast.LENGTH_SHORT).show();
}
我看了上述代码应该是手机的自制吧。我换位重新想了一下;我重新描述下我的要求;
1:先说一下为什么要这么做
手机做的系统通过webservice连接到服务器,由于很多数据是固定,不会变化得太频烦,但手机上却用得很频烦,所我现在是程序一运行后,就把这些数据下载到手机上,这时程序调用的数据不用频烦的与服务器交互,这样在使用上很快,不会操作延时的现象。
但是在某种情况下,这些数据过于庞大,所以,我的想法是:在电脑上把数据更新到数据库,然后,把数据库COPY到手机的某个目录下,当程序运行后,首先检查这个目录下是否有数据库文件,如果有就覆盖"/data/data。。。。下的数据库文件。
比如:手机上的特定存为数据库的目录为:sadb,数据库文件为:sadb.db,那么,这个代码应该如何写了(我是android新手),望兄台大大的指点
------解决思路----------------------
如果你通过USB复制到sdcard上的数据库sadb.db和APP的数据库结构完全一致的话,你可以用sadb.db直接覆盖应用的数据库.把那段代码的原地址和目标地址互换即可.
或者干脆你应用创建数据库时就直接指定目录在sdcard下
大概是:
public class MapDBHelper extends SQLiteOpenHelper {
private static final String dbFile = Environment.getExternalStorageDirectory().getAbsolutePath()+"/sadb.db";
//如果dbFile = "sadb.db";的话,系统默认地址是在data/data/xxxxx/database/下
public MapDBHelper(Context ctx) {
super(ctx,dbFile,null,DATABASE_VERSION);
}
}
这样就可以随便通过USB复制/覆盖了(坏处是别人无需root即可看到你的数据库,并对其操作)
(应用需要sdcard的读写权限<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />)