Android SQLiteOpenHelper 数据库升级

在应用开发时,可能随着需求或者其他因素,原设计的数据字段不够了需要重新新增或者删除字段,又或者创建新的表,这时我们该怎么做呢?

下面来看一个例子, 这是我们第一版开发的数据库,

package com.laomou.demo;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class SQLTest extends SQLiteOpenHelper {
	private static String DB_NAME = "people";
	private static int VERSION = 1;

	public SQLH(Context context) {
		super(context, DB_NAME, null, VERSION);
	}

	@Override
	public void onCreate(SQLiteDatabase db) {
		StringBuilder sql = new StringBuilder();
		sql.append("CREATE TABLE people");
		sql.append("(id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age TEXT);");
		db.execSQL(sql.toString());
	}

	@Override
	public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
	}

}

表结构如下

100338_AgFv_855521.png

随着需求或者其他因素,可能需要添加新字段,这是我们第二版开发的数据库,

package com.laomou.demo;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class SQLH extends SQLiteOpenHelper {
	private static String DB_NAME = "people";
	private static int VERSION = 2;

	public SQLH(Context context) {
		super(context, DB_NAME, null, VERSION);
	}

	@Override
	public void onCreate(SQLiteDatabase db) {
		StringBuilder sql = new StringBuilder();
		sql.append("CREATE TABLE people");
		sql.append("(id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age TEXT);");
		db.execSQL(sql.toString());
	}

	@Override
	public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
		int upgradeVersion = oldVersion;
		if (1 == upgradeVersion) {
			StringBuilder sql = new StringBuilder();
			sql.append("ALTER TABLE people ");
			sql.append("add class TEXT");
			db.execSQL(sql.toString());
			upgradeVersion = 2;
		}
		if (upgradeVersion != newVersion) {
			// Drop tables
			db.execSQL("DROP TABLE IF EXISTS people");
			// Create tables
			onCreate(db);
		}
	}

}

表结构如下

100644_c8af_855521.png

再来看是如何做到升级数据库,添加字段的

更改数据库的版本

private static int VERSION = 2;

实现了onUpgrade方法

int upgradeVersion = oldVersion;
if (1 == upgradeVersion) {
    StringBuilder sql = new StringBuilder();
    sql.append("ALTER TABLE people ");
    sql.append("add class TEXT");
    db.execSQL(sql.toString());
    upgradeVersion = 2;
}
if (upgradeVersion != newVersion) {
    // Drop tables
    db.execSQL("DROP TABLE IF EXISTS people");
    // Create tables
    onCreate(db);
}


转载于:https://my.oschina.net/oldmou/blog/412523

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值