7

在这个测试核心数据项目中,我有一个从“客户”到“产品”的一对多关系,这种关系被命名为“产品”。客户的属性是“名称”,产品的属性是“项目”。我对实体进行了子类化,Xcode 为客户生成了以下内容:

@interface Customer : NSManagedObject

@property (nonatomic, retain) NSString * name;
@property (nonatomic, retain) NSSet *products;
@end

@interface Customer (CoreDataGeneratedAccessors)

- (void)addProductsObject:(Products *)value;
- (void)removeProductsObject:(Products *)value;
 - (void)addProducts:(NSSet *)values;
- (void)removeProducts:(NSSet *)values;

@end

假设要添加一个客户(John Doe)和两个项目(Widget 1 和 Widget 2),我可以使用访问器方法addProductsObject,如下所示:

...
// Add (1) customer object
Customer *custObj = [NSEntityDescription insertNewObjectForEntityForName:[entity name] inManagedObjectContext:context];
[custObj setValue:@"John Doe" forKey:@"name"];

// Add (2) products for John Doe
for (int foo=0; foo<2; foo++) {
    self.product = [NSEntityDescription insertNewObjectForEntityForName:@"Products" inManagedObjectContext:context];
    NSString *objString = [NSString stringWithFormat:@"Widget %d", foo];
    self.product.item = objString;
    [custObj addProductsObject:self.product];
}
...

这很好用,但如果可能的话,我想使用addProducts访问器。

我假设生成的访问器方法addProducts是为了方便插入一组对象,例如:

...
NSSet *itemSet = [[NSSet alloc] initWithObjects:@"Widget 1", @"Widget 2", nil];
[custObj addProducts:itemSet];
...

但这失败了。在这次尝试中,我知道一个产品对象没有被显式创建,因此,一个显式的产品分配没有发生,但我认为,也许访问器会处理这个问题。

因此, addProducts以及removeProducts的正确用法是什么

谢谢。

4

1 回答 1

13

您传递给 addProducts 的集合包含 NSString,而不是 Products。

NSMutableSet* products = [NSMutableSet set];

Products* product = [NSEntityDescription insertNewObjectForEntityForName: @"Products" inManagedObjectContext: context];
product.item = @"Widget 1";
[products addObject: product];

product = [NSEntityDescription insertNewObjectForEntityForName: @"Products" inManagedObjectContext: context];
product.item = @"Widget 2";
[products addObject: product];

[customer addProducts: products];

本质上,访问者无法知道您首先给它的字符串是做什么用的。您必须提供一个包含正确类型实体的集合。

也就是说,您可以定义自己的访问器,获取一组字符串并在您的关系中插入正确初始化的产品:addProductsWithStrings:例如。

于 2012-06-13T14:39:29.743 回答