首页 > 解决方案 > iOS Swift 复合谓词

问题描述

我正在尝试在 Core Data 中搜索特定项目

我有一个实体颜色,它有一个 NSSet 的 ProjectColour 实体。ProjectColour 实体有一个名为 project 的字段,它是一个项目实体,以及两个名为 fullLeft 和 partialLeft 的 int 字段。这有一个名为 DrillType 的字段,它是一个字符串。

我正在尝试所有具有 Square 的钻类型并且 fullLeft 和 partialLeft > 0 的对象

我试过了

if searchedText.lowercased() == "square" {
    let predicateNumbers = NSPredicate(format: "ANY projectColours.fullLeft > 0 OR ANY projectColours.partialLeft > 0")
    let predicateDrillType = NSPredicate(format: "ANY projectColours.project.drillType == 'Square'")

    fetchRequest.predicate = NSCompoundPredicate(type: .and, subpredicates: [predicateNumbers, predicateDrillType])
}

这在搜索 Round 作为类型但带有正方形时有效,它返回错误的对象,即两个对象,一个是正方形但部分和完整的对象等于 0 第二个是部分等于 1 的 Round

示例 3 颜色对象

3 项目颜色对象

搜索时,我得到正方形,我得到所有 3 个结果返回,即使第二个 Project Color 对象是 Round

搜索文本时,我想要 Square 的所有 ProjectColour.project.drillType 和 ProjectColour.fullLeft > 0 AND ProjectColour.partialLeft > 0

fetchRequest.predicate = NSPredicate(format: "ANY projectColours.project.drillType == 'Square'") - Works

fetchRequest.predicate = NSPredicate(format: "ANY projectColours.fullLeft > 0 OR ANY projectColours.partialLeft > 0") - Works

但是当我尝试将两者结合起来时它不起作用

标签: iosswiftnscompoundpredicate

解决方案


假设您要搜索所有具有相关 ProjectColour 对象的所有 Color 对象,这些对象具有给定的project.drillType正数fullLeft和正数partialLeft:对于这样的请求,您需要一个 SUBQUERY。类似(未经测试):

let pred = NSPredicate(format: """
    SUBQUERY(projectColours, $pc, $pc.fullLeft > 0
                                    AND $pc.partialLeft > 0
                                    AND $pc.project.drillType ==[c] %@
            ).@count > 0
""", searchedText)

另请注意,关键字替换 with%@优于谓词格式字符串中的字符串文字,并且==[c]可用于不区分大小写的字符串比较(因此不需要将搜索文本转换为小写)


推荐阅读