繁体   English   中英

可转换的 CoreData NSPredicate 导致 EXC_BAD_ACCESS

[英]CoreData NSPredicate on a Transformable causes EXC_BAD_ACCESS

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

我有一个具有可Transformable TypeAttribute operationDays 的Entity ,该Entity是给定Custom Class [Int] 在此处输入图片说明 我用它来存储整数数组。 它的工作原理到店,但我得到EXC_BAD_ACCESS时尝试使用NSPredicate获取它们

我知道

操作天数是 {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)

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

谓词:(1 IN operationDays);

要么

谓词:(operationalDays CONTAINS 1)

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

PS要查看Sqlite抛出的错误,尝试添加

-com.apple.CoreData.SQLDebug 1

到您的 Xcode 方案中的“启动时传递的参数”。

在此处输入图片说明

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

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM