在 Android 中,SQLite 数据库的版本控制是通过 SQLiteOpenHelper 类来实现的。SQLiteOpenHelper 是一个抽象类,用于创建和更新 SQLite 数据库。它会自动处理数据库的创建、更新和版本管理。以下是实现 SQLite 数据库版本控制的步骤:
public class MyDatabaseHelper extends SQLiteOpenHelper {
// 构造函数
public MyDatabaseHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
super(context, name, factory, version);
}
// 创建数据库时调用
@Override
public void onCreate(SQLiteDatabase db) {
// 在这里创建表格
}
// 更新数据库时调用
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// 在这里处理数据库的更新操作
}
}
MyDatabaseHelper myDBHelper = new MyDatabaseHelper(this, "myDatabase.db", null, 1);
onCreate()
方法中创建表格:@Override
public void onCreate(SQLiteDatabase db) {
String CREATE_TABLE = "CREATE TABLE myTable (_id INTEGER PRIMARY KEY, name TEXT, age INTEGER)";
db.execSQL(CREATE_TABLE);
}
onUpgrade()
方法中处理数据库的更新操作。例如,如果你需要在版本 2 中添加一个新的列,可以使用以下代码:@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
if (oldVersion < 2) {
String ADD_COLUMN = "ALTER TABLE myTable ADD COLUMN email TEXT";
db.execSQL(ADD_COLUMN);
}
}
onUpgrade()
方法中添加相应的更新操作即可。注意:在实际项目中,为了避免数据丢失,建议在更新数据库时先备份原始数据。