android创建sqlite数据库及在SD卡上创建数据库

一、在手机的/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;
}
}

------------如下实例-----------

  1. package com.iaiai.activity;  
  2.   
  3. import android.content.Context;  
  4. import android.database.sqlite.SQLiteDatabase;  
  5. import android.database.sqlite.SQLiteOpenHelper;  
  6.   
  7. public class DatabaseOpenHelper extends SQLiteOpenHelper {  
  8.   
  9.     private static final String DBNAME = "iaiai"// 数据库名子  
  10.   
  11.     private static final int VERSION = 1// 版本  
  12.   
  13.     public DatabaseOpenHelper(Context context) {  
  14.         // 第三个参数CursorFactory指定在执行查询时获得一个游标实例的工厂类,设置为null,代表使用系统默认的工厂类  
  15.         super(context, DBNAME, null, VERSION);  
  16.     }  
  17.   
  18.     @Override  
  19.     public void onCreate(SQLiteDatabase db) {  
  20.         // 创建表  
  21.         db.execSQL("CREATE TABLE ADMIN (ID INTEGER PRIMARY KEY AUTOINCREMENT, NAME VARCHAR(50), PHONE VARCHAR(20))");  
  22.     }  
  23.   
  24.     @Override  
  25.     public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {  
  26.         // 升级更新  
  27.         db.execSQL("DROP TABLE IF EXISTS ADMIN");  
  28.         onCreate(db);  
  29.     }  
  30.   


但是,用此方法生成的数据库是保存在手机的/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"/>

                


你可能感兴趣的:(android,sqlite)