CoreData NSPredicate on a Transformable 导致 EXC_BAD_ACCESS
CoreData NSPredicate on a Transformable causes EXC_BAD_ACCESS
使用 NSPredicate
在 Core Data 的 Transformable
中搜索数组元素是否存在的正确方法是什么?
我有一个 Entity
,Attribute
operationalDays,Type
为 Transformable
,这是给定的 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])
使用 NSPredicate
在 Core Data 的 Transformable
中搜索数组元素是否存在的正确方法是什么?
我有一个 Entity
,Attribute
operationalDays,Type
为 Transformable
,这是给定的 Custom Class [Int]
。
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])