我正在尝试在旧的sqlite数据库表中添加新列。这些表是动态的。我的意思是,它们是在应用程序用户在应用程序中添加特定数据时创建的。
表名称具有类似的后缀。前缀取决于用户输入。现在,在android中,如何在不丢失先前数据的情况下在这些表中添加新列?
最佳答案
希望您已经知道onUpgrade
方法的工作原理。 onUpgrade
的实现非常简单,它可以检测数据库版本是否已更改,并对新版本的数据库生效。这是一个示例实现。
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// The last case will contain the break statement only. As the migration will take place one by one.
// Here's a nice explanation - http://stackoverflow.com/a/26916986/3145960
switch (oldVersion) {
case 1:
doSomeChangesInDBForVersion1();
case 2:
doSomeChangesInDBForVersion2();
break;
}
}
现在,让我们谈谈您所提出的具体问题。据我了解,数据库中的表是动态的,基于用户输入。您想在数据库表中添加基于用户输入创建的列。
在这种情况下,您需要先找出现有表,然后在每个表上运行alter命令。要查找数据库中的现有表,您可以执行以下操作。
Cursor c = db.rawQuery("SELECT name FROM sqlite_master WHERE type='table'", null);
List<String> tableList = new ArrayList<>();
if (c.moveToFirst()) {
while (!c.isAfterLast()) {
tableList.add(c.getString(0));
c.moveToNext();
}
}
现在,将表名存储在数组中,然后在每个表上运行alter命令,以在每个表中添加新列。
for (String tableName : tableList) {
db.execSQL("alter table " + tableName +" add column new_col TEXT default null");
}
在
onUpgrade
函数中运行这些执行。我尚未测试此代码。请根据您的要求进行修改。