首页
学习
活动
专区
圈层
工具
发布

如何在 Core Data 中进行批量操作

其他需要注意的还有: 批量操作最好是在私有托管对象上下文线程中进行 如果不指定谓词( NSPredicate ),意味着将删除所有的 Item 数据 所有的批量操作请求( 删除、更新、添加,以及持久化历史跟踪使用的...无论是官方给出的数据,还是开发者的实际测试,Core Data 的批量操作相较于实现相同结果的传统方式( 在托管对象上下文中使用托管对象 )来说都具有相当明显的优势 —— 执行速度快、内存占用小。...默认值为 true,因此此时这些对象是惰值( Fault )形态的 持久化存储协调器将步骤 5 中实例化的数据以托管对象数组的形式返回给发起请求的托管对象上下文 如果上下文中有部分新数据或数据改动与本次获取的条件一致...假如在其他情况下,数据没在缓存中,持久化存储会通过 SQL 语句从 SQLite 中获取到对应的数据 ) 持久化存储协调器将从持久化存储中获取的数据转交给上下文 上下文用获得到的数据填充惰值状态的 item...对所有发生变动的 item 进行验证 ( 调用 Item 的 validateForUpdate 方法中的自定义验证代码以及模型编辑器中定义的验证条件 ),如验证失败则抛出错误 调用所有需要更新的托管对象

2.4K30

详解持久化Core Data框架的原理以及使用---转自Bison的技术博客

Care Data的核心对象是托管对象上下文NSManagedObjectContext,所有实体都处于托管对象上下文管理中,Care Data应用对实体所做的任何增、删、查、改操作都必须通过托管对象上下文来完成...Care Data应用中的核心API有如下几个。 托管对象模型NSManagedObiectModel:该对象负责管理整个应用的所有实体以及实体之间的关联关系。...托管对象上下文NSManagedObjectContext:该对象是Care Data的核心对象,应用对实体所做的任何增、删、查、改操作都必须通过该对象来完成。...4.Core Data数据的增删查改 获取托管对象上下文NSManagedObjectContext之后,接下来即可通过该对象来执行增、删、查、改操作。...如下代码: // 获取将要删除的实体 Bison* deleteEvent = .....; // 从托管对象上下文中删除指定对象 [self.appDelegate.managedObjectContext

2K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SwiftUI + Core Data App 的内存占用优化之旅

    只有在访问这些托管属性时,Core Data 才会为托管对象进行数据填充( 如果行缓存中有,从缓存中取;如果没有则将数据从数据库中搬运到行缓存后再从缓存中取 )。...数据的多份拷贝 当图片数据从 SQLite 经 Core Data 最终通过 SwiftUI 显示时,实际上在内存中至少保存了三份拷贝: 行缓存 托管对象上下文( 托管对象被填充后 ) 显示该图片的 SwiftUI...原因何在??? 通过代码检查托管对象会发现,尽管托管对象已经转为惰性状态,但实际上并没有节省多少内存。...终极优化:私有上下文 + 不持有托管对象 思路 在第二轮优化中,尽管通过将托管对象转换为惰值解决了一部分内存占用问题,但存在于行缓存中的数据始终还是无法得到有效清除。...如果一条记录( 数据库中的数据 ),无论哪个上下文中都没有与其对应的托管对象,那么也将快速地清理其所占用的行缓存空间。

    2.6K10

    SwiftUI + Core Data App 的内存占用优化之旅

    只有在访问这些托管属性时,Core Data 才会为托管对象进行数据填充( 如果行缓存中有,从缓存中取;如果没有则将数据从数据库中搬运到行缓存后再从缓存中取 )。...数据的多份拷贝 当图片数据从 SQLite 经 Core Data 最终通过 SwiftUI 显示时,实际上在内存中至少保存了三份拷贝: 行缓存 托管对象上下文( 托管对象被填充后 ) 显示该图片的 SwiftUI...原因何在??? 通过代码检查托管对象会发现,尽管托管对象已经转为惰性状态,但实际上并没有节省多少内存。...终极优化:私有上下文 + 不持有托管对象 思路 在第二轮优化中,尽管通过将托管对象转换为惰值解决了一部分内存占用问题,但存在于行缓存中的数据始终还是无法得到有效清除。...如果一条记录( 数据库中的数据 ),无论哪个上下文中都没有与其对应的托管对象,那么也将快速地清理其所占用的行缓存空间。

    3.5K40

    WebGL与APP之间的通讯方

    WebGL 与 APP 之间的通讯方式,核心在于如何在 Web 环境(WebGL 运行其中)与原生环境之间建立桥梁。...JavaScript Bridge (JSBridge) - 双向通讯的核心这是 WebGL 内容(在 WebView 中)与原生 APP 之间进行通讯最常用和最核心的方式。...通讯相关: 虽然 WebGL 与原生 APP 不直接通讯,但它们可以通过共同的后端服务器作为中介进行数据同步。例如,原生 APP 将用户配置发送到后端,WebGL 从后端获取最新配置。...共享内存 / 渲染上下文共享: 原理: 让原生渲染器(如 OpenGL ES 或 Metal)和 WebView 内部的 WebGL 共享同一个渲染上下文或帧缓冲区。...在绝大多数情况下,JavaScript Bridge 是 WebGL 内容(在 WebView 中运行)与原生 APP 进行双向通讯的标准和推荐方式。

    79400

    Ask Apple 2022 中与 Core Data 有关的问答 (下)

    A:听起来这是一个有价值的功能建议,鼓励你提交反馈请求!当前,从应用程序中调用 API 是从索引中删除项目的唯一方法。当前 Spotlight 确实无法处理类似的状况。...中获取到的托管对象。...托管对象是线程绑定的。即使都来自于私有上下文但分属于不同的上下文,它也只能在其对应的上下文中使用。...我也不确定 Category/Extension 的作用以及如何在它和 Class 之间进行选择?A:大多数人会使用 Class,并在他们自己的托管对象扩展中添加他们需要的任何自定义方法。...我注意到,当我使用 Safari 客户端从 CloudKit 数据库中删除一条记录时( 通过 CloudKit Dashboard ),该对象仍会保留在设备上的 Core Data 数据存储中。

    4.8K20

    掌握 Core Data Stack

    托管对象上下文的主要职责是管理 NSManagedObject(托管对象)实例的集合,对托管对象的获取、创建、删除、修改等操作绝大多数都是在此进行。...托管对象上下文将确保一个上下文中不会出现多个托管对象实例对应同一个持久存储记录的情况,并提供了其它诸如缓存、更改跟踪、惰性加载、数据验证、变更通知等功能。...实际使用中创建多个托管对象上下文的情况并不少见。...作为协调器,它为其它组件之间创建了沟通的桥梁。无论是托管对象模型、托管对象上下文、或者持久化存储都以持久化存储协调器为核心进行协作。...在开发中的 健康笔记 3[6] 里,我需要让内存模式同非内存模式共存,也就是在特定的情况下,应用程序中同时会存在两个使用同样托管对象模型的 Container,并可随时切换。

    1.2K30

    如何在Xcode下预览含有Core Data元素的SwiftUI视图

    通常在这种情况下,我们可能会采用如下的方式来尝试解决: •删除模拟器上的应用程序重新安装运行•清除编译缓存(Clean Build Folder)•删除项目对应的派生数据(Derived Data)•重置模拟器...•在模拟器设备管理器中删除模拟器再重新添加 上述的手段,多数也都适用于修复某些情况下的预览崩溃。...SwiftUI通常采用Redux的开发模式,通过将获取到的Core Data数据转换成标准的Swift结构从而避免在视图中使用托管对象上下文或托管对象。...直接使用托管对象 当然,我们仍然可以直接给视图传递托管对象。为了便于在预览中重复使用,我们可以在CoreDataStack或其他你认为合适的地方提前创建好用于预览的数据,在预览时直接调用即可。...从Xcode 12开始,苹果在预置的CoreDataStack模版Persistence.swift中已经添加了inMemory选项,为预览创建了专用的Container。

    6.8K10

    关于 Core Data 并发编程的几点提示

    因此,在 Core Data 中进行并发编程时,请确保遵守以下规则: •托管对象上下文在初始化时被绑定到了与之相关的线程(队列)。•从托管对象上下文中检索的托管对象被绑定到了所属上下文所在的队列。...通过 NSManagedObject 来查找上下文 在某些情况下,只能获得托管对象(NSManagedObject),通过从中获取托管对象上下文,保证在正确的队列中对其操作。...context.save() }} 托管对象对应的上下文声明为unowned(unsafe),请在确认上下文仍存在的情况下使用此种方式。...image-20211104211037413 在不同的上下文之间合并更改 使用上面的 delItem 代码,在后台上下文中删除托管对象后,主线程上下文中的托管对象仍然存在。...举个例子,方便大家对保存冲突有直观的了解: •主上下文中使用 fetch 从数据库中获取了托管对象 A(对应数据库中的数据 B)•使用 NSBatchUpdaterequest (不经过上下文)修改了数据库中的数据

    1.2K20

    Ask Apple 2022 中与 Core Data 有关的问答

    如果你对查询有特别的需求的话,可以将枚举类型中关联数据打散,在实体中,将所有的关联值都定义成属性,并增加一个与枚举对应的类型属性,在托管对象中定义一个枚举类型的计算属性,通过它对数据进行转换。...A:在每个版本中添加一个新的托管对象模型会更安全,但是如果您从一个版本到另一个版本的更改经过充分测试以表明适用于轻量级迁移推断,那么单个托管对象模型就足够了。...但是,没有给出明确的提示关于如何在不影响 CloudKit 正确性的情况下以安全的方式清除历史。给出的示例是删除所有超过 7 天的事务。但是,为什么是 7 天?为什么不是 14 天?...如果我们不再关心本地数据,是否可以从与 CloudKit 同步的数据模型中删除未使用的实体?...在 Core Data 中,NSManagedObjectID 是线程安全的。通过向其他的上下文传递 ID,并通过该 ID 在不同线程的上下文中获取托管对象,这样可以确保应用不会出现崩溃。

    4.8K20

    CoreData 探秘 - 从数据模型构建到托管对象实例

    对每一个使用 Core Data 的开发者来说,用 Xcode 的 Core Data 模型编辑器构建数据模型、创建容器、加载数据模型并通过托管对象上下文最终创建托管对象实例,这都是十分普通的过程。...当我着手编写这篇文章时,又发现需要另一篇文章来具体说明 Core Data 版本的实现过程。由此偶然间诞生了这篇文章。 在本文中,我们不会深入讨论从构建数据模型到创建托管对象实例的每个细节。...viewContext.save() 然而 init(context:) 要求我们必须首先创建托管对象上下文( NSManagedObjectContext ),其实,在 Core Data 中,我们完全可以在没有上下文的情况下来创建托管对象实例...这对于某些特定情况下,只需要操作数据模型而无需操作托管对象上下文的场景非常有用。...阅读 如何在 Xcode 下预览含有 Core Data 元素的 SwiftUI 视图 一文,查看此种方法在 SwiftUI 预览中的应用。 正如前文所提到的,开发者并不一定要创建托管对象子类的实例。

    79520

    Google 是如何设计 Ruby Serverless Runtime 的?

    在坚持我们社区所熟悉的 Ruby 习惯、实践和工具的同时,我们还必须重新思考如何在几乎每个层次上进行 web 应用程序开发,从代码到依赖、持久化、测试等等。...换句话说,Ruby 虚拟机中的几乎每个对象都添加了“函数”。(当然,除非应用程序在加载文件时更改了主对象和类上下文,这种技术会带来其他风险。)在最好的情况下,这打破了封装和单一职责。...函数范式通过坚持函数不共享状态(除非通过外部持久化系统,如队列或数据库)来解决并发性问题。这实际上是我们选择使用块语法而不是方法语法的另一个原因。...同样,我们可以使用更传统的习惯用法,如 Ruby 全局变量,甚至构造函数和实例变量,将信息从启动代码传递给函数调用方。然而,这些语法可能传递了错误的东西。...我们不是在普通的 Ruby 类和方法中编写共享数据是正常的,而是在 Serverless 的函数中编写共享数据是危险的(即使可能的话),我们认为语法上强调区别是很重要的。

    3.3K60

    SwiftUI 与 Core Data —— 安全地响应数据

    删除与响应式编程托管对象的实例创建于托管上下文中,且仅能安全运行于其绑定的托管上下文所在的线程之中。每个托管对象都对应着持久化存储中的一条数据( 不考虑关系的情况下 )。...也就是说,如果一个用于显示托管对象实例数据的视图被销毁了,那么假如没有其他的视图或代码引用视图中显示的托管对象实例,托管上下文将从内存中将这些数据占用的内存释放掉。...从另一个角度来看,即使在托管上下文中使用 delete 方法删除该实例在数据库中对应的数据,但如果该托管对象实例仍被代码或视图所引用,Swift 并不会销毁该实例,此时,托管对象上下文会将该实例的 managedObjectContext...将转换过程运行于托管对象上下文所在的线程中,由于无法获取上下文信息,转换将失败。...在上节的演示中,当数据被删除后( 通过 onAppear 闭包中的延迟操作 ),NavigationView 会自动返回到根视图中。在这种情况下,持有该数据的视图将伴随着数据删除一并消失。

    4.5K20

    如何在 Core Data 中对 NSManagedObject 进行深拷贝

    对 NSMangedObject 进行深拷贝的含义是为一个 NSManagedObject(托管对象)创建一个可控的副本,副本中包含该托管对象所有关系层级中涉及的所有数据。...或者在复制托管对象某个属性(可选或设有默认值)时,选择性的不复制其内容。 以上工作都最好能在深拷贝时一并处理。 数据有效性 托管对中某些属性具有唯一性或即时性,在深拷贝中需特别处理。...例如: •上图中 Note 的 id 的类型为 UUID,在深拷贝时不应复制原来的内容而应该为新对象创建新的数据•Item 中的 NoteID 应该对应的是 Note 的 id,如何在复制过程中保持一致...而是将新拷贝的托管对象添加到与 A 的关系中,满足数据模型的设计意图。...Note 从关系链中间部分向下深拷贝(不拷贝关系链向上的部分) // 在 excludedRelationshipNames 中添加忽略的关系名称let cloneItem = try!

    2.6K20

    SwiftUI 与 Core Data —— 数据定义

    这一看似简单的转换 —— 从鸡( 托管对象 )到蛋( 结构体 )转换至从鸡( 结构体 )到蛋( 托管对象 ),将完全颠覆我们之前习惯的开发流程。...对于 SwiftUI 来说,托管对象具备两个非常显著的特点:懒加载托管对象的所谓托管是指:该对象被托管上下文所创建并持有。仅在需要的时候,才从数据库( 或行缓存 )中加载所需的数据。...在不创建 Core Data 模型的情况下,完成绝大多数的视图和逻辑代码。...如果没有 AnyConvertibleValueObservableObject ,开发者仅能对应用中的部分视图进行预览( 在不创建托管环境的情况下 ),而通过 AnyConvertibleValueObservableObject...我们将介绍如何在视图从 Core Data 中获取数据的操作这一过程中实现与托管环境解耦,创建一个可以接受 Mock 数据的自定义 FetchRequest 类型。

    3K40

    Swift实践:使用CoreData完成一个通讯录存储

    Core Data架构 一个基本的 Core Data 栈由四个主要部分组成:托管对象 (NSManagedObject),托管对象上下文 (NSManagedObjectContext),持久化存储协调器...image.png NSManagedObject是我们的数据模型,也就是我们存储的对象。这些对象都保存在NSManagedObjectContext中,每个存储对象都知道自己对应哪个上下文。...CoreData的基本读取操作 2. 1 获取CoreData已经保存数据的五个步骤 获取总代理和托管对象总管 从Entity获取一个fetchRequest 根据fetchRequest,从managedContext...要求: 从本地数据库中读取名字列表 点击增加可以添加一个名字 添加的名字可以保存到本地数据库中 好,接下来咱们来一步一步实现这个需求。...不然还要一开始分享很多其他的内容,看官们会觉得腻的。 但是,实际开发中不建议使用这种方式创建。通常情况下我们都会把生成的模板代码都删除的。

    2.2K40

    如何在 Core Data 中使用 Derived 和 Transient 属性

    Derived 什么是 Derived 属性 从 iOS 13 开始,苹果在 Core Data 中添加了 Derived(派生属性),它的名称已经表明了该属性的含义—— 该属性的值从一个或多个其他的属性的值派生而来...派生数据什么时候更新 因为是由 SQLite 直接处理的,所以只有在数据持久化时 SQLite 才会更新对应的派生数据。只在上下文中处理不持久化的话是不会获得正确的派生值的。...作为托管对象定义的一部分,Core Data 会跟踪 Transient 属性的变化,并设置对应的托管对象和托管对象上下文状态,但属性中的内容将不会被保存到持久化存储器中,也不会在持久化存储中创建对应的字段...托管对象的托管属性(使用@NSManaged 标示)是由 Core Data 来托管的,Core Data 将持续跟踪托管对象中的托管属性来设置相应的状态。...在开发 【健康笔记 3.0】[2] 的过程中,我有一处地方需要对一个包含很多关系和记录的托管对象实例进行 Deep Copy(复制其下的全部关系数据),复制后的实例将在复制完成后替换掉原来的实例(为了解决网络数据共享中遇到的特殊需求

    1.5K20
    领券