Различный счетчик через базовые данные, выражение NSE в NSFetchedResultsController

В настоящее время используется Core Data . У меня есть одна таблица, в которой я пытаюсь получить информацию в следующих строках:

SELECT item, COUNT(*) FROM myTable GROUP BY item;

для получения такого результата:

+---------+------+-------+
| item        | COUNT(*) |
+---------+------+-------+
| group 1     |   2      |
| group 2     |   5      |
| group 3     |   8      |
+---------+------+-------+

У меня возникла блестящая идея использовать выражение NSE в надежде на то, что имея Core Data делать всю работу за меня. Я начинаю крутить колеса. У меня происходит сбой функции выражения count: . Исключение не очень однозначно. Использование других функций выражения, таких как sum: , не приводит к сбою приложения.

Было бы неплохо сохранить результаты в NSFetchedResultsController . Я изучил другие варианты, ни один из которых не слишком привлекателен. Было бы лучше написать SQL-запрос и покончить с этим, чем использовать Core Data в качестве оболочки 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();
}
7
задан Coach Roebuck 6 February 2012 в 08:34
поделиться