[sqlite] android create db in SD card
refhttp://www.52php.cn/article/p-enclygcv-zm.html 一、在手机的/data/data/应用程序包名/ 目录下创建数据库。 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.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"/> (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |