我有两个类,ClassA和ClassB,关系如下:

http://img3.mukewang.com/643f621a0001b5e407440450.jpg

我需要查询所有count>10的ClassA的bObjects中name为hello的ClassB的对象。

请问能不能用一个NSPredicate来表示这个查询?


千万里不及你
浏览 90回答 2
2回答

精慕HU

看了苹果的文档,里面写的例子:If you use a to-many relationship, the construction of a predicate is slightly different. If you want to fetch Departments in which at least one of the employees has the first name "Matthew," for instance, you use an ANY operator as shown in the following example: NSPredicate *predicate = [NSPredicate predicateWithFormat:    @"ANY employees.firstName like 'Matthew'"];所以,我觉得查询应该是:NSPredicate *predicate = [NSPredicate predicateWithFormat:@"(name = %@) AND (ANY aObjects.count > 10)", @"hello"];

阿波罗的战车

脑补的,没测试。不好用请更正我NSEntityDescription *entity = [NSEntityDescription                                    entityForName:@"ClassB"                                    inManagedObjectContext:context];NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init]; [fetchRequest setEntity:entity];NSPredicate *predicate = [NSPredicate predicateWithFormat:@"(name = %@) AND (aObjects.count > 10)", @"hello"]; [fetchRequest setPredicate:predicate];
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

iOS