由于最近比较忙,导致博客没有更新。今天上午终于发布了新版本,哈!!~现在可以把之前的不足补充一下。本篇文章主要补充Android SQLite数据库版本升级的思路。
在之前一篇博文《Android SQLite 实例—增删改查、数据库版本升级》中,提到了数据库的版本升级,但是只考虑了从低版本升级到高版本的情况,并没有考虑新用户安装最新版本的情况。
额。。上面可能说的有点乱:假设有v1,v2两个版本,v1有表user;v2有表user(字段有变化),order
- 情况1:用户由v1升级到v2
- 情况2:用户直接装v2
针对上述情况1,可以采用之前博文中提到的方法。详细请参考:《Android SQLite 实例—增删改查、数据库版本升级》
针对上述情况2:可以采用以下方法。
// 在合适的地方初始化数据库
DBHelper dbHelper = new DBHelper(this);
dbHelper.getWritableDatabase();
dbHelper.close();
public class DBHelper extends SQLiteOpenHelper {
private static final String DBNAME = "Demo.db";
private static final int VERSION = 2;
public DBHelper(Context context) {
super(context, DBNAME, null, VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
DBVersionCreateManagement.InitTable(db, VERSION);
}//后面的内容没有复制过来。
/**
* 数据库表创建管理类
*
*/
public class DBVersionCreateManagement {
/**
* 初始化表
*
* @param db 数据库实例
* @param dbVersion 数据库版本
*/
public static void InitTable(SQLiteDatabase db, int dbVersion) {
switch (dbVersion) {
case 1:
CreateTable_V1(db);
break;
case 2:
CreateTable_V2(db);
break;
default:
break;
}
}
/**
* 数据库版本V1
*/
private static void CreateTable_V1(SQLiteDatabase db) {
try {
db.execSQL("");
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 数据库版本V2
*/
private static void CreateTable_V2(SQLiteDatabase db) {
try {
db.execSQL("");
} catch (Exception e) {
e.printStackTrace();
}
}
}
通过上述三个步骤,即可解决情况2描述的问题。
好了,关于数据库版本更新内容就先说这么多。欢迎朋友们留言~