草庐IT

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

coder 2024-01-17 原文

我在这里讨论了其他类似性质的问题,但它们都与在应用程序更新时替换以前的 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/

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

  1. ruby - 在 Ruby 程序执行时阻止 Windows 7 PC 进入休眠状态 - 2

    我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0

  2. ruby-on-rails - 如何验证 update_all 是否实际在 Rails 中更新 - 2

    给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru

  3. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  4. ruby - 如何指定 Rack 处理程序 - 2

    Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack

  5. ruby - 将数组的内容转换为 int - 2

    我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]

  6. ruby - 在 Ruby 中编写命令行实用程序 - 2

    我想用ruby​​编写一个小的命令行实用程序并将其作为gem分发。我知道安装后,Guard、Sass和Thor等某些gem可以从命令行自行运行。为了让gem像二进制文件一样可用,我需要在我的gemspec中指定什么。 最佳答案 Gem::Specification.newdo|s|...s.executable='name_of_executable'...endhttp://docs.rubygems.org/read/chapter/20 关于ruby-在Ruby中编写命令行实用程序

  7. ruby-on-rails - Rails 应用程序之间的通信 - 2

    我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此

  8. ruby - 无法运行 Rails 2.x 应用程序 - 2

    我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby​​:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r

  9. ruby-on-rails - Rails 应用程序中的 Rails : How are you using application_controller. rb 是新手吗? - 2

    刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr

  10. ruby-on-rails - 使用 rails 4 设计而不更新用户 - 2

    我将应用程序升级到Rails4,一切正常。我可以登录并转到我的编辑页面。也更新了观点。使用标准View时,用户会更新。但是当我添加例如字段:name时,它​​不会在表单中更新。使用devise3.1.1和gem'protected_attributes'我需要在设备或数据库上运行某种更新命令吗?我也搜索过这个地方,找到了许多不同的解决方案,但没有一个会更新我的用户字段。我没有添加任何自定义字段。 最佳答案 如果您想允许额外的参数,您可以在ApplicationController中使用beforefilter,因为Rails4将参数

随机推荐