请高人:rover11,关注一下此帐,万分感激

本文介绍了一种在Android设备上通过USB将本地更新的数据库文件复制到应用程序使用的数据库的方法,包括无需ROOT权限直接复制数据库文件的具体步骤及代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

============问题描述============


之前提出的要求如下:
自己写个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新手),望兄台大大的指点

============解决方案1============


如果你通过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" />)

转载于:https://www.cnblogs.com/liangxieliang56/p/4030415.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值