Android访问已存在的SQLite数据库

上篇文章讲的是用DatabaseHelper新建一个数据库再进行增删改查,但大多数情景是数据库已经存在了,那怎么去访问呢?思路是先判断data/data/<package_name>/databases目录下数据库是否存在,如果不存在,用流操作把res/raw或assets目录下的数据库拷贝到data/data/<package_name>/databases目录,接下来就跟新建完数据库一样一样了。

核心代码

private void getData(){
        final String DATABASE_PATH="data/data/"+ this.getPackageName() + "/databases/";
        String databaseFile=DATABASE_PATH+"mydb.db";
        //创建databases目录(不存在时)
        File file=new File(DATABASE_PATH);
        if(!file.exists()){
            file.mkdirs();
        }
        //判断数据库是否存在
        if (!new File(databaseFile).exists()) {
            //把数据库拷贝到/data/data/<package_name>/databases目录下
            try {
                FileOutputStream fileOutputStream = new FileOutputStream(databaseFile);
                //数据库放assets目录下
                //InputStream inputStream = getAssets().open("mydb.db");
                //数据库方res/rew目录下
                InputStream inputStream=getResources().openRawResource(R.raw.mydb);
                byte[] buffer = new byte[1024];
                int readBytes = 0;

                while ((readBytes = inputStream.read(buffer)) != -1)
                    fileOutputStream.write(buffer, 0, readBytes);

                    inputStream.close();
                    fileOutputStream.close();
                } catch (IOException e) {
            }
        }
        db = SQLiteDatabase.openOrCreateDatabase(databaseFile, null);
    }





  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值