現在使用中コアデータ。その結果、このタイプのを生成するためにコアデータによる個別カウント、NSFetchedResultsControllerへのNSExpression
SELECT item, COUNT(*) FROM myTable GROUP BY item;
:私はこれらの線に沿って情報を取得しようとしていた中で一つのテーブルを持っている
+---------+------+-------+
| item | COUNT(*) |
+---------+------+-------+
| group 1 | 2 |
| group 2 | 5 |
| group 3 | 8 |
+---------+------+-------+
私はNSExpressionを使用するように明るいアイデアを持っていた 、コアデータが私のためにすべての仕事を行うことを期待して。私は私の車輪を回転させ始めています。 件数:表現機能が私にクラッシュしています。例外はあまり明確ではありません。 の合計:などの他の式関数を使用しても、アプリケーションはクラッシュしません。
結果をNSFetchedResultsControllerに保存するとよいでしょう。私は他の選択肢を検討しましたが、どれも魅力的ではありません。この場合、コア・データをSQLラッパーとして使用するのではなく、SQL照会を作成して処理する方が理にかなっていますか?
参考ソースコードは以下のとおりです。
NSExpression *keyPathExpression = [NSExpression expressionForKeyPath:@"item"];
NSExpression *totalExpression = [NSExpression expressionForFunction:@"count:" arguments:[NSArray arrayWithObject:keyPathExpression]];
NSExpressionDescription * totalExpressionDescription = [[NSExpressionDescription alloc] init];
[totalExpressionDescription setExpression:totalExpression];
[totalExpressionDescription setExpressionResultType:NSInteger64AttributeType];
[totalExpressionDescription setName:@"totalInstances"];
NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
NSEntityDescription *entity = [NSEntityDescription entityForName:@"myEntity" inManagedObjectContext:self.managedObjectContext];
NSArray *propertiesToFetch = [[NSArray alloc] initWithObjects:strFieldName, totalExpressionDescription, nil];
[fetchRequest setEntity:entity];
[fetchRequest setReturnsDistinctResults:YES];
[fetchRequest setResultType:NSDictionaryResultType];
[fetchRequest setPropertiesToFetch:propertiesToFetch];
[fetchRequest setFetchBatchSize:20];
NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:strFieldName ascending:YES];
NSArray *sortDescriptors = [[NSArray alloc] initWithObjects:sortDescriptor, nil];
[fetchRequest setSortDescriptors:sortDescriptors];
NSFetchedResultsController* aFetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:[self managedObjectContext] sectionNameKeyPath:nil cacheName:nil];
...
NSError *error = nil;
if (![self.fetchedResultsController performFetch:&error])
{
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
abort();
}
NSPropertyDescriptionが不足していて、NSFetchRequestが「項目ごとのグループ化」行を追加してSQLクエリとして正しく解釈されている可能性があります。私は投稿時にそのオブジェクトを認識していませんでした。私は2月に答えを返すことができた...笑。これは、私が将来このソリューションを使用することを決めた場合には、知っておいてよかったです。あなたの応答は高く評価されます。 :-) –
1つの注釈は、元の著者がNSFetchedResultsControllerをグループ化して使用すると述べました。残念ながら、 'setPropertiesToGroupBy'が機能するためには、' setResultType:NSDictionaryResultType'が必要です。これは、変更の追跡を無効にします。 http://stackoverflow.com/a/4361198/287403 –
を参照してください。カウントをすべて並べ替えることは可能ですか? – Andy