CoreData NSPredicate on a Transformable 导致 EXC_BAD_ACCESS

CoreData NSPredicate on a Transformable causes EXC_BAD_ACCESS

使用 NSPredicate 在 Core Data 的 Transformable 中搜索数组元素是否存在的正确方法是什么?

我有一个 EntityAttribute operationalDays,TypeTransformable,这是给定的 Custom Class [Int] 我用它来存储整数数组。它可以存储但是我在尝试使用 NSPredicate

获取它们时得到 EXC_BAD_ACCESS

我知道

operationalDays is {1,2,3,4}

我正在尝试,但它们都因错误而失败。

//day is an Int (1) in this case

NSPredicate(format: "%d IN operationalDays",day) 
NSPredicate(format: "%i IN operationalDays",day) 
NSPredicate(format: "%@ IN operationalDays",day) 
NSPredicate(format: "operationalDays CONTAINS %d",day) 
NSPredicate(format: "operationalDays CONTAINS %i",day)
NSPredicate(format: "operationalDays CONTAINS %@",day)

当我在崩溃后检查谓词时,我得到

predicate: (1 IN operationalDays);

predicate: (operationalDays CONTAINS 1)

可转换属性作为二进制数据存储在 Sqlite 数据库中。您不能 运行 查询该数据,除非您的谓词也有二进制数据。可转换属性遵守 NSCoding 协议,因此,Core Data 知道如何序列化和反序列化属性。

P.S。要查看 Sqlite 抛出的错误,请尝试添加

-com.apple.CoreData.SQLDebug 1

到 Xcode 方案中的 "Arguments Passed on Launch"。

你应该使用这种风格的谓词

let predicate = NSPredicate(format: "%@ IN days", argumentArray: [valueOfArgumentHere])