gpt4 book ai didi

iphone - 在 iPhone 应用程序更新时将内容更新/插入到现有的 Sqlite 数据库中

转载 作者:塔克拉玛干 更新时间:2023-11-02 10:14:04 26 4
gpt4 key购买 nike

我在这里讨论了其他类似性质的问题,但它们都与在应用程序更新时替换以前的 sqlite 数据库有关。我一直在为所有以前的应用程序这样做,因为它们本质上是引用性的,一个简单的替换就足够了。

我正在使用的这个特定应用程序是一个问答游戏,需要保持分数。目前有 4 个级别,大约有 15 个问题,在以后的更新中这些可能会增加。由于我以前从未这样做过,所以我很好奇并打算第一次以正确的方式做到这一点。所以这是我的查询:

  1. 更新 SO 大师推荐的内容的首选方法是什么?是否有一个版本号(可能在数据库本身中)并且在新应用程序首次运行时,新内容被插入到表中?
  2. 存储插入查询的首选方式是什么?它们是否应该在实现文件中进行硬编码?

附言。我将数据库复制到 Documents 目录,因此它会在应用程序更新时保留。

编辑:我应该补充说,测验应用程序是一种“ Logo 测验”复制品,其中需要维护所有问题的分数(或将回答/未回答的问题的状态)。所以第一个版本有 60 个问题,它们的状态随着用户回答而改变。

编辑 2:这是我最关心的表结构,问题表:

_id (Integer, PRIMARY Key), levelId (Integer), QuestionImage (Varchar), CorrectAnswer(Varchar), boolAnsweredCorrectly(Integer).

测验类似于 Logo 测验。有一张图片,用户必须输入答案。如果键入的答案与数据库中的正确答案匹配,则 boolAnsweredCorrectly 设置为 true。我主要关心的是 boolAnsweredCorrectly(根据结果为 0 或 1)。

编辑 3:当我谈到在应用程序更新时插入数据时,我的意思是这个。假设第一个版本有 60 个问题。在第二个版本中增加了 40 个新问题。因此,当用户将应用程序更新到第二个版本时,需要将新的 40 个问题插入到问题表中。这是为了保证之前的 60 道题没有被弄乱并保持原样。

最佳答案

What is the preferred way to update the content that the Gurus of SO recommend? Is it to have a version number (perhaps in the DB itself) and upon first run of the new app, the new content is inserted in the table?

取决于您使用数据库是否只是为了存储此人的答案结果(在这种情况下,除了存储此人的测验回答外,您可能不需要对表进行任何“插入”发生)或者您是否也有一些单独的表来存储原始问题(如果您不通过某些服务器界面提供新问题,这可能是有意义的)。

我个人在 configuration 表中使用 database_version 字段,格式为“major.minorrevision",其中 majorminor 预设需要数据库更新的数据库更改,而 revision 更改则不需要) .但是我使用这个数据库版本号系统来知道我是否想将我的包的数据库重新复制到 Documents 中(但我这样做只是为了对我的数据库进行结构更改,并且更喜欢通过服务器获取新数据界面,但这取决于您的解决方案是如何设计的)。如果您确实以编程方式确定要再次复制数据库,如果您有任何需要保留的数据,但根据 Retterdesdialogs 的观点,您可能希望将旧数据库中的任何数据保存到新数据库中。

What is the preferred way to store the insert queries? Should they be hardcoded with in an implementation file?

无论如何,我认为您不应该有大量的硬编码 INSERT 语句,所以这不是问题。我从您下面的评论中了解到,您预计会尝试根据用户之前拥有的版本插入新的问题记录。

就我个人而言,我更倾向于

  • 将您最新和最重要的问题放入包中的数据库中
  • 让应用根据应用的预期检查Documents 数据库版本,
  • 如果不同 (a) 保存用户的旧答案; (b) 将新数据库从 bundle 复制到 Documents; (c) 根据旧数据库的答案更新新数据库中的答案。

您当然可以通过编程方式插入记录,但是想象一下当您的应用程序发布到第 20 版时会是什么样子,您将不得不根据之前的内容来确定插入内容的大量条件逻辑该应用程序的版本是(因为您不能假设用户将始终拥有以前的版本......他们可能有几个版本已过时)。当您将每个版本视为添加、删除和修改问题的组合时,它会变得更加复杂。

最重要的是,我倾向于当前问题的数据库,必要时将其复制到 Documents,只需确保该应用程序是否有包含旧答案的旧数据库,然后手动保存它们。 (或者您可以将答案存储在单独的数据库中。)

或者,我怀疑这超出了您的意愿,但您可能需要考虑使用 Core Data,这是首选的 iOS 持久存储模型。它似乎已经解决了 Core Data Model Versioning and Data Migration 中概述的迁移问题。 .我从来没有使用过 Core Data 的迁移/版本控制的东西(我一直都是自己动手),但它看起来很有前途。

关于iphone - 在 iPhone 应用程序更新时将内容更新/插入到现有的 Sqlite 数据库中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12084989/

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