android中sqlite数据库操作

我们在开发数据库应用的过程中,对表的结构有时候会有变化,特别是有时候增加了一些表,或者是增加了一些列。在调试时就会产生一些问题。

比如原来有一个表TABLEa。

在开发过程中增加了另外一个表TABLEb.并相应增加了访问了的代码。

private static class DatabaseHelper extends SQLiteOpenHelper {
DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}

@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(DATABASE_A_CREATE);
db.execSQL(DATABASE_B_CREATE);
}

}

如果数据库已经建立,这时候对TABLEb进行访问会有EXCEPTIOn产生,原因是ONCREATE只在第一次创建数据库时运行,如果数据库已经创建好了,则不会运行,所以我们访问的B表是不存在的。

遇到这种情况,以前我都是通过文件系统,把数据库文件删除。然后再运行就没有问题 了。可是这样做的缺点是特别麻烦,充分利用ONUPGRADE则可以轻松的达到数据库更新的目的。


代码如下

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
Log.w(TAG, "Upgrading database from version " + oldVersion + " to " + newVersion
+ ", which will destroy all old data");
db.execSQL("DROP TABLE IF EXISTS TABLEa");
onCreate(db);
}



onupGRADE在数据库版本变化时运行到,所以只要改一下版本号,就会强制使数据库变化到最新的设计。

当然, 在你的应用发布时,别忘了恢复成你想要的版本。而且更要记得的是,如果在两次发布之间,数据库的结构有变化,也要变更版本号。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值