NSDate値を指すキーを使用してNSSortdescriptorを使用して、NSFetchRequestの結果を並べ替えようとしています。私のフェッチ結果は、明確な理由もなく完全にランダムになります。
私が使用しているNSManagedObjectContextは、NSOperationのサブクラスで作成されたネストされた子コンテキストからの保存で更新されます。親(メイン)コンテキストから必要なすべてのデータを取得できるため、これがすべて正常に行われたことを知っています。それからフェッチすると、日付でソートされません!
奇妙なことは; 2つの日付の間でエンティティ(「Tweet」と呼ばれる)を選択するための述語は問題なく機能します。
これが私の問題を説明するためのいくつかのコードです:
NSSortDescriptor* timeDescriptor = [NSSortDescriptor
sortDescriptorWithKey:@"time"
ascending:NO
selector:@selector(compare:)];
NSFetchRequest* request = [NSFetchRequest fetchRequestWithEntityName:@"Tweet"];
[request setSortDescriptors:[NSArray arrayWithObjects:timeDescriptor, nil]];
NSPredicate* predicate = [NSPredicate predicateWithFormat:@"((time >= %@) AND (time <= %@))",startDate,endDate];
[request setPredicate:predicate];
NSManagedObjectContext* context = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSPrivateQueueConcurrencyType];
[context setParentContext:[[NSApp delegate] managedObjectContext]];
[context performBlock:^{
NSError* error = nil;
NSArray* results = nil;
results = [context executeFetchRequest:request error:&error];
// Results here are not ordered correctly
// 2nd try sorting results using fetched array (works!)
results = [results sortedArrayUsingDescriptors:[NSArray arrayWithObjects:timeDescriptor, nil]];
// This works too but not needed anymore
/*results = [results sortedArrayUsingComparator:^(id obj1, id obj2) {
Tweet* tweet1 = (Tweet*)obj1;
Tweet* tweet2 = (Tweet*)obj2;
//return [tweet1.time compare:tweet2.time]; // ascending
return [tweet2.time compare:tweet1.time]; // descending
}];*/
if ([results count] > 0) {
for (uint i = 0; i < [results count]; i++) {
Tweet* tweet = [results objectAtIndex:i];
NSDate* date = Tweet.time;
NSLog(@"tweet date: %@", date);
}
}
}];
NSSortDescriptorがフェッチで機能しない理由を誰かに教えてもらえますか?
ありがとう!
- アップデート -
PerformBlockメソッドを使用せずに、メインスレッドのメイン(親)managedObjectContextからフェッチすると、NSSortDescriptorが正常に機能するようです。これでも、NSPrivateQueueConcurrencyTypemanagedObjectContextでソートされたフェッチを実行するのに役立ちません。PerformBlock内にNSFetchRequest、NSSortDescriptor、およびNSPredicateを作成しても、問題は修正されません。