Android开发之数据库的拷贝

前言:很多时候我们开发的app,在用户第一次使用的时候,是没有联网的,但是app里面必须要有数据,但是这个数据从哪来的啊,那就是从app安装的时候,里面自带一个有数据的数据库,供用户查询使用,比如:查询手机号码的归属地,地名,等等...,,今天我就来讲述一下,如何app一打开里面就初始化好数据库。

-----------------分割线-------------

要想打开安装好的app有数据,那我们肯定要实现准备好一个数据库了,然后在moudle的目录下新建assets文件夹,然后把你的数据库文件拷贝到此文件夹下,先用getAssets().open(数据库名字.db),然后用io流把数据库读取到你的app目录下,当然这一过程执行在splashActivit中。

ok我们看具体的拷贝数据库的代码:

private void copyDb(String dbName) {
	// data/data/包名/files
	File filesDir = getFilesDir();
	File targetFile = new File(filesDir, dbName);

	// 先判断文件是否存在,如果存在,无需拷贝
	if (targetFile.exists()) {
		System.out.println("数据库" + dbName + "已经存在,无需拷贝!");
		return;
	}

	InputStream in = null;
	FileOutputStream out = null;
	try {
		AssetManager assets = getAssets();
		in = assets.open(dbName);

		out = new FileOutputStream(targetFile);

		int len = 0;
		byte[] buffer = new byte[1024];
		while ((len = in.read(buffer)) != -1) {
			out.write(buffer, 0, len);
		}
	} catch (IOException e) {
		e.printStackTrace();
	} finally {
		try {
			in.close();
			out.close();
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	System.out.println("拷贝数据库" + dbName + "成功!");
}

------------------分割线------------------

ok,以上简单的代码就可以把数据库拷贝到你的app的files目录下,当然地址你也可以自己指定。

我么来看下如何管理数据(我们这里就不使用单例了):

public class MyDao {

	private static final String PATH = "/data/data/你的包名/files/数据库名字.db";

	public static void query(String number) {
		String address = "未知号码";

		SQLiteDatabase database = SQLiteDatabase.openDatabase(PATH, null,
				SQLiteDatabase.OPEN_READONLY);// 打开数据库, 只支持从data/data目录打开,
									
		//在这里你就可以进行你的增删改查逻辑了
		
		database.close();

	}
}
切记:数据库路径千万不要写错,不能从assets打开,打开数据库, 只支持从data/data目录打开。

---------------------完-------------------



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

等待着冬天的风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值