在 Android 中,SQLite 数据库的版本控制是通过 SQLiteOpenHelper 类来实现的。SQLiteOpenHelper 是一个抽象类,用于创建和更新 SQLite 数据库。它会自动处理数据库的创建、更新和版本管理。以下是实现 SQLite 数据库版本控制的步骤:
- 创建一个继承自 SQLiteOpenHelper 的类:
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()
方法中添加相应的更新操作即可。
注意:在实际项目中,为了避免数据丢失,建议在更新数据库时先备份原始数据。