- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
如何调用数据库的onUpgrade
方法?
我的问题背景:我在完整数据库的 sdcard 上做了一个备份。并且用户可以恢复这个数据库。
但是,如果在此期间(在备份和恢复之间)应用更新更改了数据库,我将在恢复时遇到问题。恢复后新列不存在。
所以我想调用 onUpgrade
方法来添加所有新的/更改的列。
或者有什么更好的方法吗?
最佳答案
恢复后,关闭所有打开的数据库句柄,然后使用您的 SQLiteOpenHelper
获取可写数据库。这应该会触发 onUpgrade()
被调用,AFAIK。
关于database - 自己调用 onUpgrade 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2173606/
我正在尝试通过向我的 android 应用程序中的 Sqlite 表添加一列来升级某个表。我在我的 DBHelper 的 onUpgrade 方法中添加了一个 alter table 语句。 这是我遇
我正在尝试调用 onUpgrade() 来更新我的包含几列的表格。然而,当我运行该应用程序时,我在插入语句中收到一条错误消息,指出该表中不存在列(我尝试在 onUpgrade() 中添加的列)。非常感
我对 onUpgrade 有点困惑。我正在开发我的应用程序,在开发过程中我确实更改了 DATABASE_VERSION 五次,所以现在是 6。 一切都很顺利,直到我从手机上完全卸载应用程序并重新构建它
我是 Android 和数据库的新手,我在 DatabaseIncomeOutcome.java 类中有这个方法: public DbHelper(Context context) {
我在 android 中的 SQLite 数据库中遇到问题。 在 SQLiteOpenHelper 类的 onCreate(SQLiteDatabase db) 方法中,我正在创建表。现在我在 Pla
我正在尝试更新我的 Android 应用程序中的数据库。当我更新版本号时,会调用 onUpgrade,但版本号不会增加,因此每次访问数据库时都会调用 onUpgrade。这是我的代码: private
我正在开发我的应用程序的第二个版本。我遇到了一个问题。 在我的应用程序中,数据库位于 Assets 文件夹中。现在我想从第二个版本的 Assets 文件夹更新我的数据库。 我尝试将代码升级为: //
我已经使用 onUpgrade() 添加了一个表,现在我刚刚意识到需要添加另一个表。我希望在不丢失任何以前的数据或表格的情况下执行此操作。 我尝试从 onUpgrade 中删除所有内容以添加新表,但它
我正在使用预填充的数据库。在 Mozilla 中使用 SQLite Manager,现在我有一个虚拟数据库,只是想测试 onUpgrade 方法,因此我更改了其中一列中的字符串,将其导出为新数据库,正
您可以在下面看到我的数据库助手类。我使用在 Assets 文件夹中导入的预填充 SQLite 数据库。每当我向现有数据库添加表时,如果我的应用程序已安装在手机上,则不会出现此类表错误。我想我的 onU
我在表格中添加了一列 (SUM)。我认为重写/重新创建表所需要做的就是为 DATABASE_VERSION 创建变量,但这不起作用。我的 onUpgrade() 方法中需要一些东西吗? 版本变量: p
您好,我目前正在开发一款语言词典应用。该数据库来 self 手动输入的 SQLite 数据库。该应用程序的特点是用户可以要求添加任何不在列表中的单词,因此每次更新应用程序时我都必须手动更新数据库。 问
情况是这样的。我正在升级我的数据库,添加一个列。升级似乎很顺利。我可以看到添加了新列,但问题是当我的应用程序从旧版本升级到带有新数据库的新版本时,我强制关闭了。访问新列时似乎发生强制关闭。但是,如果我
我的 onUpgrade 函数有一个小问题。代码如下: @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int n
我的 Android 应用程序中有一个只读数据库,我会定期更新该数据库。该应用始终在其 Assets 中携带最新版本的数据库。 我增加了传递给 SQLiteOpenHelper 子类的构造函数的版本号
在我的应用程序中,我有一个数据库,它是使用 DBHelper 类中的数据库查询创建的。我希望 onUpgrade 语句在安装 apk 时运行,因为用户可能会卸载并安装相同的应用程序。 在这种情况下,它
在我的 dbHelper 中: onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) 函数我将一张表保存到外部数据库。 所以我 附加
我正在尝试将我的数据库从版本 1 升级到版本 2。我正在分配 DATABASE_VERSION = 2(也分配了第一个版本)但从未调用过 onUpgrade .可能代码中有明显的错误,但我看不到它,因
在我的 Android 项目中,我有一个使用了一段时间的表。现在我想删除一列“image_byte”并添加一个新列“image_path”。我不能只是在使用应用程序时重命名该列,并且需要删除 imag
有人能解释一下如何在 SqliteDbOpenHelper 类中调用 onUpgrade 函数吗?我正在打开我的数据库,但它没有调用 onUpgrade,即使我已经更改了 DB_VERSION。 见以
我是一名优秀的程序员,十分优秀!