我有两个核心数据实体,文章
和收藏夹
。 Articles
与Favorite
具有一对多关系。首先,我成功插入了所有 Articles
对象。
现在,我尝试在“收藏夹”实体中插入 ArticleID,但我做不到。要么插入一个空关系的记录,要么插入“文章”实体中的新记录。
我认为我应该先在 Articles
实体中获取相关记录,然后使用它插入到 Favorite
中,但我不确定如何执行此操作。我当前的代码:
NSManagedObjectContext *context =[appDelegate managedObjectContext] ;
favorite *Fav =[NSEntityDescription insertNewObjectForEntityForName:@"favorite" inManagedObjectContext:context];
Articles * Article = [NSEntityDescription insertNewObjectForEntityForName:@"Articles" inManagedObjectContext:context];
NSError *error;
NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
NSEntityDescription *entity = [NSEntityDescription
entityForName:@"Articles" inManagedObjectContext:context];
[fetchRequest setEntity:entity];
NSPredicate *secondpredicate = [NSPredicate predicateWithFormat:@"qid = %@",appDelegate.GlobalQID ];
NSPredicate *thirdpredicate = [NSPredicate predicateWithFormat:@"LangID=%@",appDelegate.LangID];
NSPredicate *comboPredicate = [NSCompoundPredicate andPredicateWithSubpredicates:[NSArray arrayWithObjects: secondpredicate,thirdpredicate, nil]];
[fetchRequest setPredicate:comboPredicate];
NSArray *fetchedObjects = [context executeFetchRequest:fetchRequest error:&error];
for (NSManagedObject *info in fetchedObjects) {
// ?????????????????????????
}
}
如有任何建议,我们将不胜感激。
最佳答案
首先,确保您在 Article
和 Favorite
之间存在互惠关系,即双向关系。像这样:
Article{
favorites<-->>Favorite.article
}
Favorite{
article<<-->Article.favorites
}
在 Core Data 中定义相互关系意味着从一侧设置关系会自动为另一侧设置关系。
因此,要为新创建的 Article
对象设置新的 Favorite
对象,您只需:
Favorite *fav =[NSEntityDescription insertNewObjectForEntityForName:@"favorite" inManagedObjectContext:context];
Articles *article = [NSEntityDescription insertNewObjectForEntityForName:@"Articles" inManagedObjectContext:context];
[article.addFavoriteObject:fav];
//... or if you don't use custom NSManagedObject subclasses
[[article mutableSetValueForKey:@"favorites"] addObject:fav];
如果 Article
对象或 Favorite
对象已经存在,您将首先获取该对象,但设置关系的方式完全相同。
关键是确保您拥有相互关系,以便托管对象上下文知道在两个对象中设置关系。
关于objective-c - 如何在不重复的情况下插入与另一个相关的核心数据记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5880008/