关于Android SQLite数据库版本升级的补充。。

由于最近比较忙,导致博客没有更新。今天上午终于发布了新版本,哈!!~现在可以把之前的不足补充一下。本篇文章主要补充Android SQLite数据库版本升级的思路。

在之前一篇博文《Android SQLite 实例—增删改查、数据库版本升级》中,提到了数据库的版本升级,但是只考虑了从低版本升级到高版本的情况,并没有考虑新用户安装最新版本的情况。

额。。上面可能说的有点乱:假设有v1,v2两个版本,v1有表user;v2有表user(字段有变化),order

  1. 情况1:用户由v1升级到v2
  2. 情况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描述的问题。


好了,关于数据库版本更新内容就先说这么多。欢迎朋友们留言~



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值