我有两个类,一个叫Folder ,另一个叫Entry 。
在我的数据模型中,一个文件夹会包含多个条目,一个条目可以包含在不同的文件夹中。
所以每个文件夹都有一个 folderID 来标识自己,以及一个名为 entries 的关系,用于包含 Entry 实例。每个条目都有一个名为 superFolders 的反向关系,它指向包含它的文件夹。
现在是我的问题。这里我得到一个folderID 。我想使用它和 NSFetchRequest 来获取 Core Data 中这个特殊文件夹包含的所有 entries 。以下是主要代码:
let fetchRequest = NSFetchRequest<Entry>(entityName: "Entry")
fetchRequest.predicate = NSPredicate(format: "(ANY folder in %K).folderID = %i", #keyPath(Entry.superFolders), folerID)
上面代码中的格式字符串不正确,但它主要解释了我的意思。由于 superFolders 属性实际上是 Core Data 中的一个 NSSet ,所以我不能使用 superFolders.folderID == %i 作为判断条件。我真正想要的是找到其 superFolder 属性包含 any of element 的所有条目,其 folderID 属性与给定的 folderID 。
那么可以使用 NSPredicate 来表达我对 Core Data 的意思吗?
Best Answer-推荐答案 strong>
你想要:
let fetchRequest = NSFetchRequest<Entry>(entityName: "Entry")
fetchRequest.predicate = NSPredicate(format: "ANY superFolders.folderID = %@", folderID)
见 NSPredicate reference
如果您在 superFolders 关系上有更复杂的匹配,则需要使用 SUBQUERY ,但在这种情况下是一个简单的 ANY 谓词工作正常。
关于ios - 如何使用 NSPredicate 通过 CoreData 中的 NSSet 属性的元素过滤对象?,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/42054388/
|