7

如何设置获取请求以仅从具有一个特定值的实体属性中提取数据?这是我之前使用的基本代码。

-(void)fetchResults
{
    NSFetchRequest *fetchRequest = [NSFetchRequest fetchRequestWithEntityName:self.entityDescription.name];
    NSString *cacheName = [self.entityDescription.name stringByAppendingString:@"Cache"];

    // predicate code
    if (self.predicate != nil) {
        [fetchRequest setPredicate:self.predicate];
    }
    // end of predicate code

    NSSortDescriptor *sortDescriptor = [NSSortDescriptor sortDescriptorWithKey:@"name" ascending:YES];
    [fetchRequest setSortDescriptors:[NSArray arrayWithObject:sortDescriptor]];

    self.fetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:self.managedObjectContext sectionNameKeyPath:nil cacheName:cacheName];

    BOOL success;
    NSError *error;
    success = [self.fetchedResultsController performFetch:&error];
    if (!success)
    {
        NSLog(@"%@", [error localizedDescription]);
    }
}

我一直在看这个页面:http ://bit.ly/KevYwR这是正确的方向吗?

我需要使用NSPredicate还是可以不用?

感谢您的帮助,指出正确的方向等。

4

1 回答 1

19

设置 aNSFetchRequest相当于 SQL 语言中的 SELECT 语句。

这里有一个简单的例子:

NSFetchRequest *request = [[NSFetchRequest alloc] init];
[request setEntity:[NSEntityDescription entityForName:@"EntityName" inManagedObjectContext:moc]];

NSError *error = nil;
NSArray *results = [moc executeFetchRequest:request error:&error];

// error handling code

该数组results包含 sqlite 文件中包含的所有托管对象。如果要获取特定对象(或更多对象),则需要对该请求使用谓词。例如:

NSPredicate *predicate = [NSPredicate predicateWithFormat:@"attribute == %@", @"Some Value"];
[request setPredicate:predicate]; 

在这种情况下results,包含属性等于的对象Some Value。设置谓词等于将 WHERE 子句放在 SQL 语句中。

笔记

我想实体的名称是EntityName,它的属性被称为attribute字符串类型。

有关更多信息,我建议您阅读 Core Data 编程指南和NSFecthRequest课程参考。

希望能帮助到你。

于 2012-05-16T07:54:52.990 回答