最近我更新了我的android游戏,编辑sqlite数据库在我的表中添加新字段,更新后,我收到4个崩溃报告(其中3个来自同一设备,三星Galaxy S4)
android.database.sqlite.SQLiteException:无法降级数据库
版本 2 到 1 位于
android.database.sqlite.SQLiteOpenHelper.onDowngrade(SQLiteOpenHelper.java:361)
在
android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:255)
在
android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:164)
我真的不明白可能是什么原因,甚至可以开始降级数据库,而实际上需要升级我的上一个数据库。
在更新过程中,我明显将 DATABASE_VERSION 值从 1 增加到 2
我没有重写 onDowngrade 方法,我的 onUpgrade 如下所示:
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
{
updateToVersion2(db, oldVersion, newVersion);
}
private void updateToVersion2(SQLiteDatabase db, int oldVersion, int newVersion)
{
if (oldVersion <= 1)
{
ContentValues cv1 = new ContentValues();
cv1.put(FIELD_WORLD_ID, 6);
cv1.put(FIELD_MAX_UNLOCKED, 1);
db.insert(TABLE_LEVELS, null, cv1);
}
}
谢谢。