平常一些数据都是在数据库文件写好的,但是安卓却没有直接导入的功能。

android系统下数据库一般存放在/data/data/com.*.*(package name)/ 目录下,所以我们需要做的是把已有的数据库传入那个目录下。

操作方法是用FileInputStream读取原数据库,再用FileOutputStream把读取到的东西写入到那个目录。


Android studio工程为例

操作方法:1. 在java和res的同级目录下,新建assets目录,把原数据库platform_home.db文件(db文件可以用SQLiteExpertPers.exe工具查看和编辑)放在在项目源码的assets 目录下


2、编写拷贝资源文件的方法copyAssetsFile,注意:资源文件的获取方法如下:

context.getClass().getClassLoader()
.getResourceAsStream("assets/" + fileNmae); //读入资源文件

/**
* 复制资源文件
* @param context
* @param desPath
* @param fileNmae
*/
public static void copyAssetsFile(Context context, String desPath,String fileNmae) {
try {
int bytesum = 0;
int byteread = 0;
File desfile = new File(desPath+"/"+fileNmae);
if (!desfile.exists()) { //文件不存在时
InputStream inStream = context.getClass().getClassLoader()
.getResourceAsStream("assets/" + fileNmae); //读入资源文件
FileOutputStream fs = new FileOutputStream(desPath+"/"+fileNmae);
byte[] buffer = new byte[4096];
int length;
while ( (byteread = inStream.read(buffer)) != -1) {
bytesum += byteread; //字节数 文件大小
fs.write(buffer, 0, byteread);
fs.flush();
}
fs.close();
inStream.close();
LogUtil.i("数据库已拷贝!");
}
}
catch (Exception e) {
LogUtil.i("复制单个文件操作出错");
e.printStackTrace();

}

}

3、如果拷贝成功的话,DDMS可以看到下图,然后获取数据库。

privateSQLiteDatabase database;

database
= SQLiteDatabase.openOrCreateDatabase(DBManager.DB_PATH +
"/"+ DBManager.DB_NAME,null);


更多相关文章

  1. android 文件读取(assets)
  2. Java操作数据库之jdbc【原生方式】
  3. JAVA环境下创建JSP文件报错: The superclass "javax.servlet.http
  4. 【JavaWeb-6】HttpServletResponse的字符字节输出流、编码、文件
  5. Java 简单解决springmvc获取properties文件里面中文内容出现论码
  6. 解决Eclipse建立Maven项目后无法建立src/main/java资源文件夹的
  7. java读写中文文件
  8. java文件上传输入输出流的问题
  9. Android MediaCodec硬解码AAC音频文件(实时AAC音频帧)并播放

随机推荐

  1. 详解PHP序列化和反序列化
  2. 分享几种PHP并发场景的解决方案
  3. 完整示例php+pdo实现的购物车类
  4. 分享php生成不重复随机数、数组的4种方法
  5. 详解php-fpm中max_children的配置
  6. 示例PHP实现单文件、多个单文件、多文件
  7. 聊聊PHP中的单例模式与静态变量
  8. 了解一下PHP 8的 JIT 特性!
  9. 探秘PHP number_format函数原理及实例解
  10. 直击PHP array_reverse() 函数原理及实例