- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试在旧的 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/
我是 firebase 的新手,我正在尝试分页查询。我喜欢有一个“下一个”和“上一个”按钮。我的下一个按钮工作正常,我的问题是单击上一个 引用:https://firebase.google.com/
抱歉,标题这么蹩脚,但我只是不知道该放什么,希望你能理解。另外,我不知道以前是否有人问过类似的问题,因为我不知道合适的关键字 - 因此也无法用谷歌搜索。 基本上...在查看preg_match_all
我想在 TFS 中 check out 一个检入文件的先前版本。我可以轻松获得特定文件的变更集 ID 列表,但无法弄清楚如何 checkout 以前的版本。 我目前的代码: var workspace
我想使用 @FunctionalInterface来 self 代码中的 Java 8,但我希望能够将生成的类文件与 Java 6 一起使用。我认为我应该将源版本设为 1.8 , 目标版本为 1.6
自从 versions 被删除以来,我一直无法找到安装以前版本软件的方法。命令并点击 Homebrew。我在 2008 Mac Pro (3,1) 上运行 macOS 10.14.3 (Mojave)
当我开始当前的项目时,App Store 中已经有一个应用程序。此应用程序仅适用于 iPhone。 我的第一个任务是测试和构建一个也可以在 iPod Touch 上运行的版本。 大约 3 周前,App
我在 GitHub 上有一个曾经是 fork 的 repo,但现在不是了,因为我已经删除了原始项目的任何痕迹并开始了一个同名的新项目。 但是,GitHub 仍然表示该项目是 fork 的。有什么方法可
我是一名优秀的程序员,十分优秀!