向应用添加 Core Data 及相关操作指南
1. 数据获取与性能优化
在某些场景下,无需使用获取请求(fetch request)来获取家庭成员的喜爱电影。可以直接遍历家庭成员与电影的关系来获取这些信息,这样做不仅方便开发者,还能提升应用性能。因为每次使用获取请求都会触发对数据库的查询,而遍历关系时,Core Data 会尝试从内存中获取对象,而非向数据库查询。
当添加新数据时,表格视图不会立即更新内容。在了解如何过滤数据后,会进一步探讨解决此问题的方法。若要检查代码是否生效,可构建并重新运行应用,以便从数据库中获取最新数据。
2. 使用谓词过滤数据
在数据库操作中,过滤数据是常见需求。在 Core Data 里,可使用谓词(predicate)来实现。谓词描述了一组规则,被获取的对象必须符合这些规则。
在模型编辑器中对数据进行建模时,应考虑所需的过滤类型。例如,若构建生日日历,常需按日期排序或过滤,此时应为该属性添加 Core Data 索引。可在模型编辑器中通过复选框启用索引,这能显著提升在大型数据集中过滤和选择数据的性能。
编写谓词可能会让人困惑,尤其是将其与 SQL 中的 where 子句相比较时。虽然二者相似,但并不完全相同。简单的谓词示例如下:
NSPredicate(format: "name CONTAINS[n] %@", "Gu")
谓词有特定格式,总是以键(key)开头,该键代表要匹配的属性,如上述示例中的家庭成员姓名。接着指定条件,常见的有 <
超级会员免费看
订阅专栏 解锁全文
6

被折叠的 条评论
为什么被折叠?



