更新就像创建一个新的一样简单。
要更新特定对象,您需要设置NSFetchRequest。此类相当于 SQL 语言中的 SELECT 语句。
这里是一个简单的例子:
NSFetchRequest *request = [[NSFetchRequest alloc] init];
[request setEntity:[NSEntityDescription entityForName:@"Favorits" inManagedObjectContext:moc]];
NSError *error = nil;
NSArray *results = [moc executeFetchRequest:request error:&error];
// error handling code
数组results 包含sqlite 文件中包含的所有托管对象。如果要获取特定对象(或更多对象),则需要对该请求使用谓词。例如:
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"title == %@", @"Some Title"];
[request setPredicate:predicate];
在这种情况下,results 包含标题等于 Some Title 的对象。设置谓词等于将 WHERE 子句放在 SQL 语句中。
有关更多信息,我建议您阅读 Core Data 编程指南和 NSFecthRequest 类参考。
希望对你有帮助。
EDIT(可用于更新的sn-p)
// maybe some check before, to be sure results is not empty
Favorits* favoritsGrabbed = [results objectAtIndex:0];
favoritsGrabbed.title = @"My Title";
// save here the context
或者如果您没有使用NSManagedObject 子类。
// maybe some check before, to be sure results is not empty
NSManagedObject* favoritsGrabbed = [results objectAtIndex:0];
[favoritsGrabbed setValue:@"My title" forKey:@"title"];
// save here the context
在这两种情况下,如果您对上下文执行 save,数据将被更新。