CoreData 合并冲突显示托管对象版本更改而不是数据

Posted

技术标签:

【中文标题】CoreData 合并冲突显示托管对象版本更改而不是数据【英文标题】:CoreData merge conflict shows managed object version change not data 【发布时间】:2016-09-15 09:52:52 【问题描述】:

我在核心数据中有一个实体,我尝试从两个不同的上下文中更新它。我正在存储我需要更新的托管对象的 managedObjectID,因为它是线程安全的。在更新我的对象之前,我会刷新对象以避免合并冲突。这是我的代码:

context1.performBlock 
    let myObject = context1.objectWithID(managedObjectId)
    context1.refreshObject(myObject, mergeChanges: true)
    myObject.property1 = newValue

请注意,我没有在此处保存上下文,因为我想将这些更改作为事务的一部分与其他更新一起提交。

对于同一个对象,我还有一些其他属性需要立即提交,因此我为此创建了单独的上下文以防止 property1 立即提交。

context2.performBlock 
    let myObject = context2.objectWithID(managedObjectId)
    context2.refreshObject(myObject, mergeChanges: true)
    myObject.property2 = newValue
    do 
        try context2.save()
    
    catch 

在上面的代码中,在context2 上,我更新了property2,它将立即提交给db,但在我的情况下这不是那么频繁的更新。在context1 上,我经常更新property1(每1 秒),我每10 秒提交一次(请注意,每次更新property1 时,我都会刷新对象,所以我会得到property2 的更新值曾被 context2 更改)。

这在大多数情况下都可以正常工作,但有时我会遇到合并冲突。我不知道为什么每次刷新对象后都会出现合并冲突。

我的控制台也向我显示了相同的对象,除了托管对象的版本,所以如果所有属性都与版本的更新方式相同?

控制台日志:

错误域=NSCocoaErrorDomain 代码=133020 “无法合并更改。”用户信息=冲突列表=( “NSManagedObject (0x18751830) 的 NSMergeConflict (0x17fa78f0),objectID 为‘0x170f1ca0’,oldVersion = 8,newVersion = 9,旧对象快照 = \n property1 = value1;\n property2 = value2\n和新的缓存行 = \n property1 = value1;\n property2 = value2\n" )

如您所见,旧对象快照和新缓存行具有相同的数据,但版本不同。

【问题讨论】:

This answer 解决您的问题。 【参考方案1】:

正如@Husam 在评论中提到的,尝试将MergePolicy 上的ManagedObjectContext 设置为:

 managedObjectContext.mergePolicy = NSMergeByPropertyObjectTrumpMergePolicy

希望对您有所帮助!

【讨论】:

以上是关于CoreData 合并冲突显示托管对象版本更改而不是数据的主要内容,如果未能解决你的问题,请参考以下文章

撤消已发布的合并并重新应用原始更改而不重写历史记录

解决RestKit中的CoreData合并冲突,当一个上下文正在保存对象更新而另一个正在删除对象时

更改 coredata 版本时合并数据

更新当前的 CoreData 条目

CoreData:打开独立的 .xcdatamodeld 文件并更改当前模型版本

传递核心数据对象而不保存