4

我有一个具有以下接口的 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 关系。

我第一次尝试保存条目时效果很好,但第二次却不行。

案例场景:我添加了一个日期为 2013-07-26 00:00:00 +0000 的实体,其各自的组织和人员。

我重新启动应用程序。它执行当前日期(7/27)的搜索,但没有找到任何东西。我开始在应用程序上编辑内容,因此它使用 MagicalRecord 的便捷方法 [Assistance createEntity] 创建了一个新实体;我立即设置日期(7/27)和组织。Person 对象被添加或删除。选择另一个日期后,我尝试保存当前的援助对象实体,为此,我自己实施了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;

我错过了关于核心数据的一些东西吗?为什么在保存新实体对象时访问第一个插入的对象?为什么组织为零?

4

1 回答 1

8

看起来你没有创建一个新的organisation. 相反,您将新Assistance对象链接到现有的organisation. 因为这种关系1 to 1意味着旧对象与损坏的Assistance对象有关系。organisation这是由 Core Data 自动完成的,以维护您设置的配置的完整性。

因此,要么创建一个新organisation对象,要么更改关系多重性。

于 2013-07-28T06:53:43.637 回答