如何使用NSPredicate根据子元素进行过滤?

时间:2011-05-15 03:23:32

标签: objective-c core-data nspredicate

我正在使用核心数据;假设我在员工和部门之间存在多对一关系,员工存储在每个部门的NSSet中。我想找到只有一名员工的所有部门。如何使用Core Data执行此操作?

我尝试了下面的代码,我得到一个例外,说MYEmployee没有回复allObjects

NSPredicate *predicate = [NSPredicate predicateWithFormat:@"ANY SELF.employees.allObjects.count == 1"];
singleEmployeeDepartments = [[myModelController allDepartments] filteredArrayUsingPredicate:predicate]];

1 个答案:

答案 0 :(得分:7)

首先,您并未在此处高效使用Core Data,因为您始终从数据存储中获取所有部门,然后在内存中过滤生成的数组。您可以直接查询托管对象上下文以查找匹配的部门,而不是获取所有部门,这可以减少内存消耗,如果您有很多部门,也可能更快。

NSManagedObjectContext *moc = ...;
NSFetchRequest *request = [[[NSFetchRequest alloc] init] autorelease];
[request setEntity:[NSEntityDescription entityForName:@"Department" inManagedObjectContext:moc]];
[request setPredicate:[NSPredicate predicateWithFormat:@"employees.@count == 1"]];
NSArray *singleEmployeeDepartments = [moc executeFetchRequest:request error:NULL];

另一个关键部分是使用谓词字符串中的@count运算符来查询具有特定员工数量的部门。