[英]Core Data NSPredicate for relationships
我的對象圖很簡單。
我有一個feedentry對象,它存儲有關RSS提要的信息和一個名為Tag的關系,該關系鏈接到“TagValues”對象。 關系(to和inverse)都是to-many。 即,饋送可以具有多個標簽,並且標簽可以與多個饋送相關聯。
我提到了如何通過關系進行核心數據查詢? 並創建了一個NSFetchRequest。 但是在獲取數據時,我得到一個異常說明,
NSInvalidArgumentException謂詞的未實現SQL生成
我該怎么辦? 我是核心數據的新手:(我知道我做了一件非常糟糕的事情......請幫忙......
謝謝
-
NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
// Edit the entity name as appropriate.
NSEntityDescription *entity = [NSEntityDescription entityForName:@"FeedEntry" inManagedObjectContext:managedObjectContext];
[fetchRequest setEntity:entity];
// Edit the sort key as appropriate.
NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"authorname" ascending:NO];
NSArray *sortDescriptors = [[NSArray alloc] initWithObjects:sortDescriptor, nil];
[fetchRequest setSortDescriptors:sortDescriptors];
NSEntityDescription *tagEntity = [NSEntityDescription entityForName:@"TagValues" inManagedObjectContext:self.managedObjectContext];
NSPredicate *tagPredicate = [NSPredicate predicateWithFormat:@"tagName LIKE[c] 'nyt'"];
NSFetchRequest *tagRequest = [[NSFetchRequest alloc] init];
[tagRequest setEntity:tagEntity];
[tagRequest setPredicate:tagPredicate];
NSError *error = nil;
NSArray* predicates = [self.managedObjectContext executeFetchRequest:tagRequest error:&error];
TagValues *tv = (TagValues*) [predicates objectAtIndex:0];
NSLog(tv.tagName); // it is nyt here...
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"tag IN %@", predicates];
[fetchRequest setPredicate:predicate];
// Edit the section name key path and cache name if appropriate.
// nil for section name key path means "no sections".
NSFetchedResultsController *aFetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:managedObjectContext sectionNameKeyPath:nil cacheName:@"Root"];
aFetchedResultsController.delegate = self;
self.fetchedResultsController = aFetchedResultsController;
-
這里的關鍵是“任何”
蘋果的例子:
NSPredicate *predicate = [NSPredicate predicateWithFormat:
@"ANY employees.firstName like 'Matthew'"];
你需要SQLite嗎? 我正在努力解決類似的問題,並發現一切都按照預期的方式運行二進制存儲。
使用SQLite作為商店時存在一些限制,但我還沒有找到列出限制的文檔,只列出它們存在的限制。
對不起,我無法提供更多幫助。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.