gpt4 book ai didi

ios - 核心数据 NSBatchDeleteRequest 似乎将对象留在上下文中

转载 作者:技术小花猫 更新时间:2023-10-29 10:07:00 24 4
gpt4 key购买 nike

我在 Core Data 中看到过很多关于批量删除的问题,但似乎没有一个能解决我的问题。

我正在使用 Core Data 创建一个 iOS 9/Swift 应用程序。在今年的 WWDC 上,我参加了核心数据 session ,看到我可以使用 NSBatchDeleteRequest直接从持久存储中删除大量对象。这对我来说适用于某些对象而不适用于其他对象,我认为这与我的人际关系有关。

我有一个由 Subject 组成的对象图和 Course ,其中存在一对多关系。受试者可以拥有任意数量的类(class)。

Subject 上有一个“类(class)”关系删除规则为 Cascade ,因为我想要与 subject 关联的所有类(class)当 subject 时被删除被删除。

相反的是 Course 上的“主题” , 删除规则为 Nullify .在这里,我对 Apple 对 Nullify 的描述有点困惑。 :

Remove the relationship between the objects but do not delete either object. This only makes sense if the department relationship for an employee is optional, or if you ensure that you set a new department for each of the employees before the next save operation.

这很清楚,但为什么要删除关系而不是任何一个对象?如果我删除 Course , 我想要 Course被删除和来自 subject 的关系到 course被删所以误删Course不会出现在 NSSet 中在 Subjectcourses设置。

我想提供一种删除实体中所有对象的方法。当我通过单独获取和删除每个 course 来尝试此操作时, courses已正确删除并从 NSSet 中删除的 coursesSubject 上.

因为我不知道有多少 courses会出现,我想确保在每种情况下都具有高性能,我想我会使用批量删除来删除所有 courses .问题是在利用 NSBatchDeleteRequest 时删除所有 Subjects工作正常,删除所有courses一路上(因为 Cascade 规则),试图删除所有 Courses使用此方法似乎将所有对象留在原地。

我用了NSBatchDeleteRequest删除所有 Courses ,但是当我查询 MOC 时看什么SubjectsCourses仍然存在,两者都是Courses仍然返回并且 Subject拥有它们仍然有对它们的引用。

相比之下,当我获取并删除每个 Course 时单独地,我随后的提取正确地为所有 Courses 显示一个空数组和 Subject 上的“类(class)”关系似乎已被适当修改。

是的,我在执行请求后保存上下文。我想上下文可能不会被告知商店做了什么,但随后又删除了所有 subjects工作得很好。这是怎么回事?

最佳答案

the WWDC 2015 session which describes NSBatchDeleteRequest据解释,“更改未反射(reflect)在上下文中”。所以你看到的是正常的。批量更新直接在持久存储文件上工作,而不是通过托管对象上下文,因此上下文不知道它们。当您通过获取然后删除来删除对象时,您正在处理上下文,因此它知道您正在做的更改(实际上它正在为您执行这些更改)。

如果您使用 NSBatchDeleteResultTypeObjectIDs,您可以使用 mergeChangesFromRemoteContextSave:intoContexts: 将批量删除的结果合并回您的上下文中以更新您的上下文。如果您没有从上下文中加载任何其他托管对象,您也可以使用 reset

关于ios - 核心数据 NSBatchDeleteRequest 似乎将对象留在上下文中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33533750/

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