android中sqlite博客,Android 中sqlite应用

一、在手机的/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卡的读写权限:

转自:http://blog.csdn.net/chtnj/article/details/7838033

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值