我对Core Data还不熟悉,想用一个查询获取各种类型的所有子对象。比如说有一个"Animal"类型作为父类,"Cat"、"Dog"和"Bird"作为子类。我想在单个查询中获取猫和狗,但不包括鸟,以Animal对象的形式返回。这是否可能?
是的,这是可能的:
// Load delegate from application and context from delegate.
SampleAppDelegate *delegate = [[UIApplication sharedApplication] delegate];
NSManagedObjectContext *context = delegate.managedObjectContext;
// Create new request.
NSFetchRequest *request = [[NSFetchRequest alloc] init];
// Create entity description using delegate object context.
NSEntityDescription *entity = [NSEntityDescription entityForName:@"Animal" inManagedObjectContext:context];
// Set entity for request.
[request setEntity:entity];
[request setIncludesSubentities:YES];
// Load array of documents.
NSError *error;
NSArray *animals = [context executeFetchRequest:request error:&error];
// Release request.
[request release];
// Access array.
for (id animal in animals) { }
虽然这个条件 (entity.name != "Bird"
) 在你只有 "Cat", "Dog" 和 "Bird" 时可能有效,但如果你以后添加了更多的 "Animals",它就不再有效。你可以使用 entity.name == "Dog" && entity.name == "Cat"
这是一个问题:“...在你的情况下,你是否会有其他动物?”
玩得开心 =)
@property
)属性。 - Peter Hoseyentity
属性是不可用的。你别无选择,只能进行后获取过滤步骤。 - Rob Keniger