public void onUpgrade(SQLiteDatabase ab, int oldVersion, int newVersion)
时间: 2024-02-07 12:02:08 浏览: 69
`onUpgrade`是Android中`SQLiteOpenHelper`类中的一个方法,用于在数据库版本升级时执行一些操作。当应用程序升级时,如果新版本中的数据库模式或表结构发生了变化,就需要在`onUpgrade`方法中执行相应的数据库升级操作。
在`SQLiteOpenHelper`子类中重写`onUpgrade`方法,可以根据需要执行一些数据库升级操作,例如添加新表、删除旧表、修改表结构等。
下面是一个简单的示例:
```java
public class MyDatabaseHelper extends SQLiteOpenHelper {
private static final String DATABASE_NAME = "mydatabase.db";
private static final int DATABASE_VERSION = 2;
public MyDatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
// 创建表格的操作
db.execSQL("CREATE TABLE IF NOT EXISTS user (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT)");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// 升级表格的操作
if (newVersion > oldVersion) {
db.execSQL("ALTER TABLE user ADD COLUMN age INTEGER");
}
}
}
```
在上述代码中,`MyDatabaseHelper`是一个自定义的`SQLiteOpenHelper`子类。在`onCreate`方法中创建了一个名为`user`的表格,有id和name两个字段。在`onUpgrade`方法中,检查新版本号是否大于旧版本号,如果是,则执行添加一个age字段的操作。这个操作会在升级数据库时自动执行。
当应用程序升级时,如果新版本号大于旧版本号,`SQLiteOpenHelper`会自动调用`onUpgrade`方法,执行升级操作。如果不需要升级数据库,则可以不用重写`onUpgrade`方法。
阅读全文