我正在尝试在旧的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函数中运行这些执行。我尚未测试此代码。请根据您的要求进行修改。

09-25 18:45
查看更多