家长MOC获取来自儿童MOC的空数据的变化

我遇到了CoreData和Parent-Child MOC的这个问题:在向MOC添加对象时,保存它们并保存父MOC所有对象都将其属性重置为defaultValue。

我在这里粘贴了两个MOC中的日志,特别是这些日志中的“stringAttribute”和“date”属性被重置。

我到处寻找这个问题,但是我没有find任何东西,我也看了很多亲子MOC的实现,但我无法弄清楚我做错了什么。

提前致谢!

以下是代码片段:

我添加一些NSManagedObject到主上下文,然后用saveContext:方法保存

 // Another singleton method - (void)anotherMethod { [...] [self.managedObjectContext insertObject:managedObject]; NSError *error; save = [self saveContext:&error]; [...] } // Database manager singleton method - (BOOL)saveContext:(DKError *__autoreleasing *)error { __block BOOL save = NO; __block NSError *internalError; [self.managedObjectContext performBlockAndWait:^{ internalError = nil; [self.managedObjectContext log]; // See log 1.1 below save = [self.managedObjectContext save:&internalError]; if (!save) { NSLog(@"Error saving data in main context"); } else { [self.managedObjectContext.parentContext performBlock:^{ internalError = nil; save = NO; [self.managedObjectContext.parentContext log]; // See log 1.2 below save = [self.managedObjectContext.parentContext save:&internalError]; if (!save) { NSLog(@"Error saving data to disk!"); } }]; } }]; *error = [DKError errorWithNSError:internalError]; // Custom error class return save; } 

父 – 子上下文代码

 - (NSManagedObjectContext *)writerObjectContext { if (_writerObjectContext != nil) return _writerObjectContext; NSPersistentStoreCoordinator *coordinator = [self persistentStoreCoordinator]; if (coordinator != nil) { _writerObjectContext = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSPrivateQueueConcurrencyType]; [_writerObjectContext setPersistentStoreCoordinator:coordinator]; } return _writerObjectContext; } - (NSManagedObjectContext *)managedObjectContext { if (_managedObjectContext != nil) { return _managedObjectContext; } _managedObjectContext = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSMainQueueConcurrencyType]; [_managedObjectContext setParentContext:[self writerObjectContext]]; return _managedObjectContext; } 

日志1.1

 Inserted objects: {( <Entity: 0x9595120> (entity: Entity; id: 0x9582d40 <x-coredata:///Entity/t24D0F98B-CB94-41D3-BEDD-79913454A9152> ; data: { [...] dateAttribute = "2013-07-12 10:36:31 +0000"; stringAttribute = ricercaEntity; [...] }) )} 

日志1.2

 Inserted objects: {( <Entity: 0xb53ce80> (entity: Entity; id: 0x9582d40 <x-coredata:///Entity/t24D0F98B-CB94-41D3-BEDD-79913454A9152> ; data: { [...] dateAttribute = "2013-01-05 11:00:00 +0000"; stringAttribute = nil; [...] }) )} 

UPDATE

我应该提到被添加到上下文中的managedObject是用上下文nil初始化的。 然后在调用saveContext:之前saveContext:我检查是否存在object.managedObjectContext ,如果它是零,那么我将设置为[self managedObjectContext] ,使用上面的方法创build的。 因此,无论是用nil上下文创buildmanagedObject ,还是使用以下命令创build:

 + (id)newObjectForInsertion { return [[self alloc] initWithEntity:[self entityDescription] insertIntoManagedObjectContext:[DKDatabaseManager defaultManager].managedObjectContext]; } 

关联的managedObjectContext位于同一个队列(NSMainQueueConcurrencyType)中。

否则,如果managedObject是使用+newObjectForInsertion创build的,则所有saveContext: concurrency-chain返回YES,并将所有更改传递给父上下文。

我不知道这是一个错误还是CoreData应该工作的方式。

苹果开发者论坛同样的问题:

https://devforums.apple.com/thread/174677?tstart=90

你应该使用concurrencyType来初始化上下文:

 context = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSPrivateQueueConcurrencyType]; 

另外,设置合并策略

 [context setMergePolicy:NSMergeByPropertyObjectTrumpMergePolicy]; 

NSMergeByPropertyObjectTrumpMergePolicy

此策略合并持久存储的对象版本和当前的内存版本之间的冲突,优先考虑内存中的更改。 合并发生的个人财产。 对于在外部源和内存中已经更改的属性,内存中的更改将胜过外部源。

顺便说一句,我发现了类似的问题: 奇怪行为,当使用child-parent-nsmanagedobjectcontext看看使用通知合并接受的答案。