我正在使用核心数据;假设我在员工和部门之间存在多对一关系,员工存储在每个部门的NSSet
中。我想找到只有一名员工的所有部门。如何使用Core Data执行此操作?
我尝试了下面的代码,我得到一个例外,说MYEmployee没有回复allObjects
。
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"ANY SELF.employees.allObjects.count == 1"];
singleEmployeeDepartments = [[myModelController allDepartments] filteredArrayUsingPredicate:predicate]];
答案 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
运算符来查询具有特定员工数量的部门。