我在 Android 上编写应用程序并使用 SQlite 数据库。我希望能够通过用户选择将列添加到我的表中。因此用户可以将他想要的任何列添加到表中。例如,用户有“动物”表,他想为“狗”、“猫”和“鱼”添加列。
我已经阅读了一些解决方案,但我没有看到可以帮助我的解决方案。我读到添加列的简单方法是使用:
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// If you need to add a column
if (newVersion > oldVersion) {
db.execSQL("ALTER TABLE " + TableName + " ADD COLUMN " + ColumnName);
}
}
但是我的问题是我无法选择将由用户选择添加到表中的列的名称,字符串没有参数。所以我尝试使用这样的东西,并直接调用它。
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion, String newColumnName) {
// If you need to add a column
if (newVersion > oldVersion) {
db.execSQL("ALTER TABLE " + TableName + " ADD COLUMN " + newColumnName);
}
}
但是我得到了这个方法的错误。
我还有一个关于数据库版本的问题。调用 onCreate 时会自动调用 onUpgrade 方法。在 onUpgrade 中有用于数据库版本的 oldVersion 和 newVersion 参数。什么时候设置 oldVersion 和 newVersion 参数?我如何将我的 newVersion 参数设置为 2、3、4 ...?