- objective-c - iOS 5 : Can you override UIAppearance customisations in specific classes?
- iphone - 如何将 CGFontRef 转换为 UIFont?
- ios - 以编程方式关闭标记的信息窗口 google maps iOS
- ios - Xcode 5 - 尝试验证存档时出现 "No application records were found"
我在 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
中在 Subject
的 courses
设置。
我想提供一种删除实体中所有对象的方法。当我通过单独获取和删除每个 course
来尝试此操作时, courses
已正确删除并从 NSSet
中删除的 courses
在 Subject
上.
因为我不知道有多少 courses
会出现,我想确保在每种情况下都具有高性能,我想我会使用批量删除来删除所有 courses
.问题是在利用 NSBatchDeleteRequest
时删除所有 Subjects
工作正常,删除所有courses
一路上(因为 Cascade
规则),试图删除所有 Courses
使用此方法似乎将所有对象留在原地。
我用了NSBatchDeleteRequest
删除所有 Courses
,但是当我查询 MOC
时看什么Subjects
和 Courses
仍然存在,两者都是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/
这是我的jade雕像: section#entry-review-template.template(data-class='entry-review') table thead
我是一名优秀的程序员,十分优秀!