0

我有一个简单的 XCDataModel,其中包含一个具有一个属性的实体。本质上,我正在保存一系列日期。

现在,我知道我正在正确添加 NSDates,因为我在添加它们后运行了一个 fetch 请求并运行了如下结果:

for (NSManagedObject *info in fetchedObjects) {
    NSLog(@"Name: %@", [info valueForKey:@"attribute"]);
}

并且每增加一个 NSDate 都会被计算在内。来自日志的示例:

2012-06-19 12:40:38.531 Arts Days[47194:16103] Name: 2013-03-27 04:00:00 +0000
2012-06-19 12:40:38.531 Arts Days[47194:16103] Name: 2013-03-01 05:00:00 +0000
2012-06-19 12:40:38.532 Arts Days[47194:16103] Name: 2013-01-01 05:00:00 +0000

现在,当我尝试从 Core Data 中删除一个对象时,它被证明是不成功的(通过运行相同的 fetch 并再次运行结果)。

这是获取:

NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
NSEntityDescription *entity = [NSEntityDescription entityForName:@"Entity" inManagedObjectContext:self.managedObjectContext];
[fetchRequest setEntity:entity];

[fetchRequest setFetchBatchSize:366];

NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"date" ascending:NO];
NSArray *sortDescriptors = [NSArray arrayWithObjects:sortDescriptor, nil];

NSError *error = nil;

[fetchRequest setSortDescriptors:sortDescriptors];

NSArray *fetchedObjects = [self.managedObjectContext executeFetchRequest:fetchRequest error:&error];

for (NSManagedObject *object in fetchedObjects) {
    if ([[object valueForKey:@"date"] isEqualToDate:date]) {
        [managedObjectContext deleteObject:object];
    }
}
if (![managedObjectContext save:&error]) {
    NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
}

此外,带有未解决错误的 NSLog 包含 nil nil ...

你知道我做错了什么吗?

4

1 回答 1

1

看来您使用了两个不同的NSManageObjectContext实例。self.managedObjectContext(一个 ivar)来设置你的获取请求并执行获取,但是一个本地实例来执行deleteObject:andsave:操作。本地实例managedObjectContext可能是 nil 并且没有引用与 ivar 相同的对象。

于 2012-06-19T16:49:55.250 回答