1

嗨,我将来自数据库的值保存在 MultableArray 中,然后保存在 CoreData 中:

 NSMultableArray *mutary = [[NSMultableArray alloc] init];
      NSManagedObjectContext *context = [app managedObjectContext];
    for(int n=0; n<[AttributeArray count]; n++)
    {

    [mutary addObject:[[AttributeArray objectAtIndex:n] objectForKey:@"AttributName"]];
    NSLog(@"%@", mutary);
}
attributeString = [mutary componentsJoinedByString:@","];

 raume = [NSEntityDescription insertNewObjectForEntityForName:@"Raum" inManagedObjectContext:context];

raume.raumattribut = attributeString;

 if (![context save:&error]) {
 NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
 abort();

}

MultableArray 的 NSLog 输出为:

    2012-06-20 17:21:00.047 book-app[31984:15803] (
    A7OVERHEAD,
    Beamer
)

到目前为止,它的工作正常。数据库中的两个预期值现在位于数组中。现在我从 CoreData 获取这些属性:

    NSManagedObjectContext *context = [app managedObjectContext];
    NSFetchRequest *request = [[NSFetchRequest alloc] init];
    NSEntityDescription *entity = [NSEntityDescription entityForName:@"Raum" inManagedObjectContext:context];
    [request setEntity:entity];
    NSError *error = nil;
    NSArray *events = [context executeFetchRequest:request error:&error];

for (Raum *att in events)
    {
     stringAttribute = [[events valueForKey:@"raumattribut"] componentsJoinedByString:@","];
     NSLog(@"ATTRIBUTE: %@", stringAttribute);
    }
}

到目前为止,一切都很好。但是,如果我现在查看我的 NSLog 输出:

2012-06-20 17:21:00.055 book-app[31984:15803] ATTRIBUTE: <null>,A7OVERHEAD,Beamer

CoreData 正在返回,然后是两个值。那是从哪里来的?

有人可以帮忙吗?

提前致谢

4

1 回答 1

1

编辑:经过一些调查和澄清(见评论),这是我的答案:在 NSArray 上调用 valueForKey 返回一个数组,其中每个元素都是通过在原始数组的每个成员上调用 valueForKey 创建的。这意味着您的输出表明您的 fetch 请求返回了 3 个对象,而第一个对象没有设置它的 raumattribut 属性。

上一个答案:您在 NSArray 的实例(查询结果)上调用 valueForKey。也许你需要获取 objectAtIndex:0首先使用要迭代值的变量?valueForKey 可能返回 nil。

stringAttribute = [[att valueForKey:@"raumattribut"] componentsJoinedByString:@","];

或类似的。

编辑:起初我错过了第二部分的 for 循环,我编辑了上面的代码示例以使用 attr,它

于 2012-06-20T15:46:55.857 回答