gpt4 book ai didi

java - 更新 SQLite 表而不丢失以前在 android 中的数据

转载 作者:塔克拉玛干 更新时间:2023-11-01 23:01:41 25 4
gpt4 key购买 nike

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

关于java - 更新 SQLite 表而不丢失以前在 android 中的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49292002/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com