加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

[sqlite] android create db in SD card

发布时间:2020-12-12 20:01:53 所属栏目:百科 来源:网络整理
导读:refhttp://www.jb51.cc/article/p-enclygcv-zm.html 一、在手机的/data/data/应用程序包名/ 目录下创建数据库。 如果创建的数据库的大小比较小的话,可以用android自带的SQLiteOpenHelper类直接将数据库生成在手机的/data/data/应用程序包名/目录下,方法如

refhttp://www.52php.cn/article/p-enclygcv-zm.html

一、在手机的/data/data/应用程序包名/ 目录下创建数据库。
如果创建的数据库的大小比较小的话,可以用android自带的SQLiteOpenHelper类直接将数据库生成在手机的/data/data/应用程序包名/目录下,方法如下:
写一个MySQLiteOpenHelper类继承自SQLiteOpenHelper类,并重写onCreate和onUpdate方法。

public class MyDatabaseHelper extends MySQLiteOpenHelper {
    //数据库名称
    public final static String DATABASE_NAME="db";
    //数据库版本
    public final static int DATABASE_VERSION=1;
    MyDatabaseHelper(final Context context) {
        super(context,DATABASE_NAME,null,DATABASE_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        //创建数据库表
    }

    @Override
    public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion) {
        if(newVersion!=oldVersion){             
        //更新数据库
        }
        oldVersion=newVersion;
    }
}



但是,用此方法生成的数据库是保存在手机的/data/data文件夹下的,
这会带来两问题:
1、如果手机本身的存储空间较小,则对创建的数据库的大小进行了限制。
2、如果无法获取手机的Root权限,则无法直接查看创建的数据库文件。
鉴于以上问题,通常情况下把数据库放在存储卡上是一个较好的选择。


二、在SD卡上创建数据库
通过android的SQLiteOpenHelper类的源码,可以看到SQLiteOpenHelper类的getWritableDatabase。
这个接口实际上调用的是Context的openOrCreateDatabase方法,而这个方法是不支持带路径的数据库名称的。
也就是说,用这个方法创建的数据库只能放在/data/data/包名称/ 目录下。
要想在SD卡上创建数据库,我们可以调用SQLiteDatabase类的openOrCreateDatabase方法,这个方法是支持带路径的数据库名称的。
那么下面的问题就是如何判断是否存在SD卡,已经如何获取SD卡的路径了?
判断是否存在SD卡:

android.os.Environment.MEDIA_MOUNTED.equals(android.os.Environment.getExternalStorageState());

获取SD卡路径:
String dbPath=android.os.Environment.getExternalStorageDirectory().getAbsolutePath();

在SD卡上创建数据库方法如下:
String dbPath=android.os.Environment.getExternalStorageDirectory().getAbsolutePath()+"/database";
File dbp=new File(dbPath);
File dbf=new File(dbPath+"/"+"test.db");       
if(!dbp.exists()){
       dbp.mkdir();
 }                 
//数据库文件是否创建成功
boolean isFileCreateSuccess=false;      
if(!dbf.exists()){
  try{                 
    isFileCreateSuccess=dbf.createNewFile();
      }catch(IOException ioex){
             
     }     
}else{
    isFileCreateSuccess=true;
}
if(isFileCreateSuccess)
    db = SQLiteDatabase.openOrCreateDatabase(dbf,mFactory);

为了简便起见,我们可以用上述方法重写SQLiteOpenHelper类的getWritableDatabase方法,其他逻辑参照SQLiteOpenHelper类即可。
最后别忘了,加入SD卡的读写权限:
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读