核心数据 NSPredicate 使用 in 子句获取实体关系

Core Data NSPredicate fetch on entity relationship using in clause

我希望能够使用 IN 子句搜索实体的关系。 我有以下设置:

我想发送一组昵称并找到所有与这些昵称关联的人。

//array of names to find
let nameArray: [String] = ["Tom", "Tommy", "Thomas"] 

// find all Persons who have a nickname associated with that person           
let predicate = NSPredicate(format: "ANY Person.nickName in %@",nameArray)
var fetch = NSFetchRequest(entityName: "Person")
fetch.predicate = predicate
var fetchError : NSError? = nil

// executes fetch
let results = context?.executeFetchRequest(fetch, error: &fetchError)

但是当我 运行 代码时,出现以下错误:

'NSInvalidArgumentException',原因:'unimplemented SQL generation for predicate : (ANY Person.nickName IN {"Tom", "Tommy", "Thomas"})'

我在这里做错了什么?如果我删除谓词搜索,它 returns 所有结果都正常,但只要我添加这一行,一切都会中断。

您应该在 NSPredicate 中使用关系名称。
试试这个:

let predicate = NSPredicate(format: "ANY personToNick.nickName in %@", nameArray)