Kap*_*isa 4 core-data nsmanagedobject nsmanagedobjectcontext ios merge-conflict-resolution
我在核心数据中有一个实体,我尝试从两个不同的上下文更新它。我正在存储我需要更新的托管对象的 managedObjectID,因为它是线程安全的。在更新我的对象之前,我刷新对象以避免合并冲突。这是我的代码:
context1.performBlock {
let myObject = context1.objectWithID(managedObjectId)
context1.refreshObject(myObject, mergeChanges: true)
myObject.property1 = newValue
}
Run Code Online (Sandbox Code Playgroud)
请注意,我没有在此处保存上下文,因为我想将这些更改作为其他更新事务的一部分提交。
对于同一个对象,我还有一些其他属性需要立即提交,因此我为此创建了单独的上下文以防止 property1 立即提交。
context2.performBlock {
let myObject = context2.objectWithID(managedObjectId)
context2.refreshObject(myObject, mergeChanges: true)
myObject.property2 = newValue
do {
try context2.save()
}
catch {}
}
Run Code Online (Sandbox Code Playgroud)
在上面的代码中context2,我已经更新了property2,它将立即提交给 db,但在我的情况下这不是那么频繁的更新。在context1我更新property1的频率(以every1秒),我提交它每10秒(请注意,我每次更新property1,我刷新对象,所以我会得到更新的价值property2一旦被改变context2)。
这在大多数情况下都可以正常工作,但有时我会遇到合并冲突。我不知道为什么每次刷新对象后我都会遇到合并冲突。
此外,我的控制台向我显示了相同的对象,除了托管对象的版本,所以如果所有属性都与版本更新的方式相同?
控制台日志:
错误域=NSCocoaErrorDomain 代码=133020 “无法合并更改。” UserInfo={conflictList=( "NSMergeConflict (0x17fa78f0) for NSManagedObject (0x18751830) with objectID '0x170f1ca0' with oldVersion = 8 and newVersion = 9 and old object snapshot = {\n property1 = value1;\n property2 = value2\n} and新缓存行 = {\n property1 = value1;\n property2 = value2\n} " )}
如您所见,旧对象快照和新缓存行具有相同的数据,但版本不同。
正如在评论中提及的@Husam,尝试设置MergePolicy上ManagedObjectContext为:
managedObjectContext.mergePolicy = NSMergeByPropertyObjectTrumpMergePolicy
Run Code Online (Sandbox Code Playgroud)
希望这有帮助!
| 归档时间: |
|
| 查看次数: |
3114 次 |
| 最近记录: |