我有一个带有以下界面的NSManagedObject。
@class Organization, Person;
@interface Assistance : NSManagedObject
@property (nonatomic, retain) NSDate * date;
@property (nonatomic, retain) Organization *organization; // Not optional, 1 to 1
@property (nonatomic, retain) NSSet *persons; // 1 to many
@end
人与组织有1-1关系。 协助与组织和与人的1-may关系具有1-1关系。
我第一次尝试保存条目时效果很好,但不是第二次。
案例场景:我添加了一个日期为2013-07-26 00:00:00 +0000的实体,其各自的组织和人员。
我重启了应用。它执行搜索当前日期(7/27),但没有找到任何内容。我开始在应用程序上编辑内容,因此它使用MagicalRecord的便捷方法[Assistance createEntity]创建一个新实体;我立即设定了日期(7/27)和组织。添加或删除Person对象。当选择另一个日期时,我尝试保存当前的Assistance对象实体,为此我自己实现了setCurrentDate方法:
- (void)setCurrentDate:(NSDate *)currentDate
{
if (assistanceWasChanged) {
NSLog(@"> > > Has changed, need to save with Persons {%i}, org {%@}, date {%@}", [self.assistance.persons count], self.organization.name, self.currentDate);
// [[NSManagedObjectContext defaultContext] saveOnlySelfWithCompletion:^(BOOL success, NSError *error) { NSLog(@"> > > 01:Assistance saved?"); }];
[[NSManagedObjectContext defaultContext] saveOnlySelfAndWait];
}
assistanceWasChanged = NO;
_currentDate = currentDate;
[self setCurrentAssistance]; // Tries to find Assistance with new date
}
但这一次,它不会保存。我得到一个Cocoa错误1570(并非所有必填字段都填满):
> > > Has changed, need to save with Persons {1}, org {MSF}, date {2013-07-27 00:00:00 +0000}
2013-07-27 20:23:41.017 -[NSManagedObjectContext(MagicalSaves) MR_saveWithOptions:completion:](0x8d61e50) → Saving <NSManagedObjectContext (0x8d61e50): *** DEFAULT ***> on *** MAIN THREAD ***
2013-07-27 20:23:41.018 -[NSManagedObjectContext(MagicalSaves) MR_saveWithOptions:completion:](0x8d61e50) → Save Parents? 0
2013-07-27 20:23:41.018 -[NSManagedObjectContext(MagicalSaves) MR_saveWithOptions:completion:](0x8d61e50) → Save Synchronously? 1
2013-07-27 20:23:41.018 -[NSManagedObjectContext(MagicalRecord) MR_contextWillSave:](0x8d61e50) Context DEFAULT is about to save. Obtaining permanent IDs for new 1 inserted objects
2013-07-27 20:23:41.019 CoreData: sql: BEGIN EXCLUSIVE
2013-07-27 20:23:41.019 CoreData: sql: SELECT Z_MAX FROM Z_PRIMARYKEY WHERE Z_ENT = ?
CoreData: sql: UPDATE Z_PRIMARYKEY SET Z_MAX = ? WHERE Z_ENT = ? AND Z_MAX = ?
2013-07-27 20:23:41.020 CoreData: sql: COMMIT
2013-07-27 20:23:41.021 +[MagicalRecord(ErrorHandling) defaultErrorHandler:](0x6b3a0) Error: <Assistance: 0x9cb16c0> (entity: Assistance; id: 0x9e5ac00 <x-coredata://15A3-4C6D-4025-9131-3D51048/Assistance/p1> ; data: {
date = "2013-07-26 00:00:00 +0000";
organization = nil;
persons = "<relationship fault: 0x8d80500 'persons'>";
})
在任何时候,组织都没有。此外,从未提取/编辑日期为“2013-07-26”的对象。我正在尝试添加的新对象的日期为“2013-07-27”,正如我的日志语句所示。 起初我以为CoreData有一个指向旧数据的指针,但事实并非如此,从未提取第一个插入日期。 (当我重新启动应用程序时,第一个对象(7/26)仍在那里。 如果它有所不同,则辅助实体对象是我的实现文件中的属性:
@property (strong, nonatomic) Assistance *assistance;
我是否遗漏了有关核心数据的内容? 保存新实体对象时,为什么要访问第一个插入的对象?为什么组织没有?
答案 0 :(得分:8)
您似乎没有创建新的organisation
。相反,您将新的Assistance
对象链接到现有的organisation
。因为关系是1 to 1
,这意味着旧的Assistance
对象与organisation
对象的关系已经破坏。这由Core Data自动完成,以维护您已设置的配置的完整性。
因此,要么创建一个新的organisation
对象,要么更改关系多样性。