4

我正在尝试使用谓词针对托管对象上下文执行获取请求,该谓词针对抽象类的某些子类中存在的键路径进行测试。

例如这里是对象模型的一部分

Library::NSManagedObject
 - AllMovies::to-many relationship->Movie

Movie::NSManagedObject (abstract)
 - type::String
 - name::String
 - mylibrary::to-one relationship->Library

HorrorMovie::Movie
 - monster::String
 - ghosts::BOOL

RomanceMovie::Movie
 - percociouskid::String
 - hasferret::BOOL

如果我设置以下获取请求

NSEntityDescription *entityDescription = [NSEntityDescription entityForName:@"Library" 
                                                     inManagedObjectContext:moc];
NSFetchRequest *request = [[[NSFetchRequest alloc] init] autorelease];
[request setEntity:entityDescription];
NSPredicate *predicate = [NSPredicate predicateWithFormat:
                            @"(SUBQUERY(AllMovies, $movies, 
                                                   $movies.type like[c] 'horror' and
                                                   $movies.moster like[c] 'yeti'
                                       ).@count != 0)"
                          ] 
[request setPredicate:predicate];

NSArray *array = [moc executeFetchRequest:request error:&error];

执行 fetch 请求会返回一个错误,例如

keypath $movies.monster not found in entity <NSSQLEntity Movie id=2>

似乎没有办法对谓词进行惰性求值。我已经尝试过的其他一些事情是使用 CAST 关键字的 ANY 谓词,尝试用另一个 SUBQUERY 替换 SUBQUERY 中的“AllMovies”,以返回一组与“type”值匹配的对象。

可以为每个合格类型执行多个请求,但这是粗略、缓慢和笨拙的。

这是在带有 SQL 持久存储的 OS X 10.6 下。做一个内存存储不是一个选项,因为我正在使用 100 万多个“图书馆”(该项目与电影没有任何关系,但我认为这是一个很好的例子)。

谢谢,罗伯

4

1 回答 1

1

这是行不通的,因为您的实体模型只是告诉 Core DataAllMovies关系包含Movie对象。因此,Core Data 期望能够仅发送Movie对象能够理解的那些消息。当它发起 fetch 时,它会针对每个Movie对象(由 fetch 实体指定)测试谓词。

但是,Movie实体和实体都不RomanceMovie理解monster消息(因为它们缺少属性。)谓词测试被渲染为无意义的。这就是你得到错误的原因。

你需要重新考虑你的设计。使用实体继承可能不是您想要的方式。

于 2011-02-24T21:43:16.220 回答