onUpgrade在开发过程中的另类用途
来源:互联网 发布:入门电钢琴推荐 知乎 编辑:程序博客网 时间:2024/06/15 07:43
本人是在开发ANDROID应用中的一点小技巧。
我们在开发数据库应用的过程中,对表的结构有时候会有变化,特别是有时候增加了一些表,或者是增加了一些列。在调试时就会产生一些问题。
比如原来有一个表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在数据库版本变化时运行到,所以只要改一下版本号,就会强制使数据库变化到最新的设计。
当然, 在你的应用发布时,别忘了恢复成你想要的版本。而且更要记得的是,如果在两次发布之间,数据库的结构有变化,也要变更版本号。
- onUpgrade在开发过程中的另类用途
- onUpgrade在开发过程中的另类用途
- ormlite 中的onUpgrade
- 粗浅理解接口在Android开发中的用途
- dynamic 另类用途
- 另类中的另类 Spring quartz在集群环境下解决方案
- hadoop在移动中的用途
- const在项目中的用途
- Python在测试中的用途
- “COPY”命令的另类用途
- 扩展wordpress的另类用途
- _maven.repositories的另类用途
- sql server2000在开发过程中的安全问题
- ”过程”在敏捷开发中的位置
- 数据结构在实际开发过程中的应用
- UML在软件开发过程中的应用
- 数据库在IOS开发过程中的应用
- MySQL在日常开发过程中的注意事项
- SuperMap 移动地理信息系统解决方案
- WebLogic经验:session锁定错误解决
- OpenInventor中的SoShapeKit
- Android问题集锦之四:Android requires compiler compliance level 5.0. Please fix project properties.
- Using emacs & cscope
- onUpgrade在开发过程中的另类用途
- 如何提高阅读源代码的效率
- 塔希里亚部分名言
- 安装APK文件到Android模拟器与adb命令的使用
- sharepoint designer2010点击“Externa Content Type”报错的解决办法
- android学习笔记(二) 开发时在PC上硬盘模拟SD卡
- OpenInventor的SoShpaeKit和SoShapeScale
- 函数中的参数的默认值处理
- 常见的网络数据包的数据结构