首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >SQLite数据库升级

SQLite数据库升级
EN

Stack Overflow用户
提问于 2011-07-05 17:58:03
回答 3查看 2.8K关注 0票数 1

我对android SQLite数据库的处理有点困惑。我看了一遍教程,但我没有得到确切的要点。

我们可以有一个扩展SQLiteOpenHelper的数据库类,并且可以覆盖onCreate()方法并创建一个数据库。

升级数据库部分有点令人困惑。在下面的方法中,如何处理verions onUpdate(SQLiteDatabase db,int old Version,int newVerison)

这是否意味着当我们第一次创建数据库时,版本是1。然后,一旦修改了,版本就变成了2。然后,如果我们想要再次修改旧版本= 2,newVerison =3

onUpdate(SQLiteDatabase db,int old Version,int newVerison)

此方法将在我们传递构造函数版本时执行,如以下代码所示(as 2)

代码语言:javascript
运行
复制
public DatabaseHelper(Context context) {
  super(context, dbName, null,2);
}

我需要知道当我们需要调用onUpgrade()方法时,我们是否应该总是将版本作为2传递,或者我们必须为以前的版本每次都加1。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-07-05 18:42:09

在每次模式更改时增加您的数据库版本。

您永远不需要直接调用onUpgrade。当您打开数据库时,Android将在需要时调用它,方法是将数据库的版本与您的代码指定为当前版本的版本进行比较。

你只需要在onUpgrade中处理升级过程-它可能是这样的:

代码语言:javascript
运行
复制
int curVer = oldVersion;
while ( curVer < newVersion ) {
    curVer++;
    switch ( curVer ) {
        case 2: {
            // Upgrade from V1 to V2
            break;
        }
        case 3: {
            // Upgrade from V2 to V3
            break;
        }
        case 4: {
            // Upgrade from V3 to V4
            break;
        }
    }
}

假设您的newVersion是4,oldVersion是1-第一次迭代会将curVer递增到2,并运行V2到V3的升级代码。第二次迭代将curVer递增到3并运行V2到V3的升级代码,最终迭代将curVer递增到4并运行V3到V4的升级代码。

这适用于所有小于newVersion的oldVersion值。如果您的用户跳过应用程序的升级,则将按顺序通过中间版本进行升级。

票数 9
EN

Stack Overflow用户

发布于 2011-07-05 18:01:27

我使用this approach使数据库模式演变更容易一些,您可能也会发现它也很有用。

票数 0
EN

Stack Overflow用户

发布于 2011-07-05 18:17:55

如何维护数据库的版本完全取决于你。您可以在修改表结构或修改内容后更改版本。对于维护版本控制,没有硬性规定。这取决于项目的要求。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6580849

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档