0

我正在开发一个使用 Core Data 进行存储的 iOS 应用程序。在我的商店中,每个实体都是唯一的,我正在构建一个函数,用我传入的另一个实体替换一个现有实体。这是我传递的一个实体示例:

    NSManagedObjectContext *context = [[MyDB sharedInstance] managedObjectContext];

    User *user = [NSEntityDescription insertNewObjectForEntityForName:@"User" inManagedObjectContext:context];

    NSNumber *userNumber = 12345;

    user.id = userNumber;
    user.name = @"John Doe";
    user.email = @"john@doe.net";
    user.createdDate = [NSDate date];

    [[MyDB sharedInstance] updateUser:user];

在我的核心数据存储中,我已经有一个相同的实体,除了电子邮件地址是“john@doe.com”。我现在的更新是这样的:

-(void)updateUser:(User *)user {

    NSError *error;
    NSManagedObjectContext *context = [[MyDB sharedInstance] managedObjectContext];

    // Create fetch request
    NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
    NSEntityDescription *entity = [NSEntityDescription entityForName:@"User" inManagedObjectContext:context];
    [fetchRequest setEntity:entity];

    // Create predicate
    NSPredicate *pred = [NSPredicate predicateWithFormat:@"id == %@", user.id];
    [fetchRequest setPredicate:pred];

    NSArray *results = [context executeFetchRequest:fetchRequest error:&error];

    if (error) {
        // handle fetch error
    } else {

        user = [[User alloc] initWithEntity:entity insertIntoManagedObjectContext:context];

        for (User *recordToDelete in results) {

            [context deleteObject:recordToDelete];//record gets deleted here, which is fine

        }

        [context save:&error]; //this doesn't save the new entity that I passed in

        if (error) {
            // handle save error
            NSLog(@"Whoops, couldn't save: %@", [error localizedDescription]);
        }

    }


    [fetchRequest setEntity:entity];
    NSPredicate *predicate = [NSPredicate predicateWithFormat:@"id=%@", 12345];
    [fetchRequest setPredicate:pred];

    NSArray *items = [context executeFetchRequest:fetchRequest error:&error];

    for (User *testObject in items) {

        NSLog(@"ID: %@, Name: %@, Email: %@, Created Date: %@", [testObject id], [testObject name], [testObject email], [testObject createdDate]);

    }

}

问题是上述函数删除了存储中的现有记录,但是它无法添加替换它的新实体。我该如何纠正?

4

2 回答 2

2

另外,我认为您并不清楚什么是 NSManagedObjectContext。它类似于内存中的对象缓存。因此,如果您在上下文中创建对象,则它与上下文相关联。对象具有对上下文的引用,因此不需要使用对象传递上下文 - 可以从中获取对象的上下文。此外,上下文和对象不是线程安全的 - 您不能在线程之间传递托管对象并在不同线程中使用相同的上下文。相反,您必须:
1) 为每个线程创建上下文
2) 如果您需要在线程之间传递某些内容,请object.objectId从一个线程传递,然后在另一个线程中执行[context objectWithID:]. 它非常快速、高效和安全。

于 2013-09-26T21:09:34.330 回答
1

您没有在托管对象上下文上调用 save 方法。在创建新对象的 managedObjectContext 上调用 save 方法。 [managedObjectContext save:nil];

推荐的方式是。首先根据数字获取对象,然后将其删除。之后创建托管对象。最后调用 Save on context。

于 2013-09-26T20:39:53.830 回答