android开发中,导入有数据的sqlite,与apk一起安装到手机上

sqlite比较常规的使用方式一般是这样的,就是在程序中新建一个空的数据库,然后进行增删改查等一系列的操作,这样的操作,对于小应用的开发是比较容易满足需求的,但是有些比较大的应用,包含的数据量比较大,如果在程序中,对数据进行一条一条的插入,第一,比较耗时,第二,用户体验很差,最重要的一点是显得很不专业。那么,可以想到的一种比较好的方式,就是如何将db文件与apk一起安装到手机上呢,实现方法如下:

首先,要有包含数据的sqlite文件,是db类型的,可以是你之前一条一条导入的,然后找到手机路径下/data/data/包名/database文件,将其导出就可以了;

然后,再android工程里找到assets目录,将db类型的文件放在该目录下面,准备就绪之后,上代码

public static SQLiteDatabase database;
String DB_PATH = "/data/data/com.example.mymap/databases/";
		String DB_NAME = "wifi.db";


		// 检查 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();
			}
		}


		// 下面测试 /data/data/com.test.db/databases/ 下的数据库是否能正常工作
	    database = SQLiteDatabase.openOrCreateDatabase(DB_PATH + DB_NAME, null);
		Cursor cursor = database.rawQuery("select * from wifi_private", null);//这句话没通过
         Log.v("111","111");
		if (cursor.getCount() > 0) {
			cursor.moveToFirst();
			// 解决中文乱码问题
			String SSID = cursor.getString(cursor.getColumnIndex("SSID")); 
			//byte test[] = cursor.getBlob(0);
			//String strtest = new String(test, "utf-8").trim();


			// 看输出的信息是否正确
			Log.v("SSID",""+SSID);
		}
		cursor.close();
        
		Log.v("222","222"); 


这样一来 数据库就导入成功了,需要注意的一点,该导入进去的数据库并不会和你程序中创建的数据库产生冲突(只要数据库名不同,表名相不相同无所谓),所以,有些数据是安装程序的同时导入,有些数据也可以在程序中根据用户个人的操作进行添加,并不会产生冲突。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值