1

Core Data から「ページ化された」エンティティを取得しようとしたときに、奇妙なことに遭遇しました。

フェッチに使用するコードは次のとおりです。

NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
NSEntityDescription *entity = [NSEntityDescription entityForName:@"User" 
                                          inManagedObjectContext:self.managedObjectContext];
fetchRequest.predicate = [NSPredicate predicateWithFormat:@"userIdentifier beginswith[cd] %@ AND selected == 1",userIdentifier];
fetchRequest.fetchOffset = offset;
fetchRequest.fetchLimit = limit;
[fetchRequest setEntity:entity];
NSLog(@"offset %d limit %d",fetchRequest.fetchOffset,fetchRequest.fetchLimit);

NSError *requestError = nil;
NSArray *items = [self.managedObjectContext executeFetchRequest:fetchRequest
                                                          error:&requestError];
NSLog(@"fetched items count = %d",items.count);

そして、ここにログがあります:

2013-01-31 16:01:28.127 offset 0 limit 100
2013-01-31 16:01:28.128 fetched items count = 6
2013-01-31 16:01:40.533 offset 1 limit 100
2013-01-31 16:01:40.535 fetched items count = 5
2013-01-31 16:01:53.029 offset 2 limit 100
2013-01-31 16:01:53.032 fetched items count = 4
2013-01-31 16:01:55.468 offset 3 limit 100
2013-01-31 16:01:55.470 fetched items count = 3
2013-01-31 16:02:00.776 offset 4 limit 100
2013-01-31 16:02:00.779 fetched items count = 2
2013-01-31 16:02:02.325 offset 5 limit 100
2013-01-31 16:02:02.328 fetched items count = 1
2013-01-31 16:02:03.837 offset 6 limit 100
2013-01-31 16:02:03.839 fetched items count = 0
2013-01-31 16:02:07.714 offset 6 limit 100
2013-01-31 16:02:07.717 fetched items count = 0

このテストでは、「ユーザー」に 6 つのエントリがありました。

私は何を間違っていますか?

ありがとう

4

2 に答える 2

4

ログは、すべてが期待どおりに機能していることを示しています。

おめでとう!

于 2013-01-31T14:38:54.470 に答える
0

問題が見つかりました:

fetchRequest.fetchOffset = offset*limit;
于 2013-01-31T14:39:15.113 に答える