在sdCard创建数据库(打造自己的SQLiteOpenHelper)

本文介绍如何在Android的sdCard上创建数据库,通过修改SQLiteOpenHelper的默认路径,详细阐述了getWritableDatabase()和getReadableDatabase()的实现,并讨论了并发访问时的锁机制。同时,还讲解了如何下载并读取sdCard上的db文件,以及在继承SQLiteOpenHelper后调用onCreate()和onUpgrade()的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.在sd创建数据库

        项目需求,需要在sd卡上创建数据库,看了半天的SQLiteOpenHelper代码,主要的方法就是getWritableDatabase()和getReadableDatabase(),

都是一系列的判断,然后返回SQLiteDatabase mDatabase,但是为什么就会在/data/data/com.xxxx./xxx.db呢?

      认真看了代码之后,就会发现在getReadableDatabase()方法下:

              String path = mContext.getDatabasePath(mName).getPath();//这里由上下文得到的路径就是在data/data/xxxxx目录

               db = SQLiteDatabase.openDatabase(path, mFactory, SQLiteDatabase.OPEN_READONLY);

       在getWritableDatabase()方法下有这样代码

          if (mName == null) {
                db = SQLiteDatabase.create(null);
            } else {
                db = mContext.openOrCreateDatabase(mName, 0, mFactory);//通过上下文创建数据库也是在data/data/下的
            }

那么要在sd卡上创建数据文件,那么改变他们的路径就应该可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值