前言:很多时候我们开发的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目录打开。---------------------完-------------------