CoreData получает различные значения атрибута - PullRequest
29 голосов
/ 09 августа 2011

Я пытаюсь настроить свои NSFetchRequest на базовые данные, чтобы получить уникальные значения для определенного атрибута в объекте. т.е.

субъект со следующей информацией:

  name | rate | factor |
_______|______|________|
John   |  3.2 |    4   |
Betty  |  5.5 |    7   |
Betty  |  2.1 |    2   |
Betty  |  3.1 |    2   |
Edward |  4.5 |    5   |
John   |  2.3 |    4   |

Как мне настроить запрос на возврат массива только с: Джон, Бетти, Эдвард?

Ответы [ 3 ]

71 голосов
/ 09 июля 2012

Вы должны использовать резервное хранилище, чтобы помочь вам получить различные записи.

Если вы хотите получить массив только с Джоном, Бетти и Эдвардом, вот как вы это сделаете:

NSFetchRequest *fetchRequest = [NSFetchRequest fetchRequestWithEntityName:@"MyEntity"];
NSEntityDescription *entity = [NSEntityDescription entityForName:@"MyEntity" inManagedObjectContext:self.managedObjectContext];

// Required! Unless you set the resultType to NSDictionaryResultType, distinct can't work. 
// All objects in the backing store are implicitly distinct, but two dictionaries can be duplicates.
// Since you only want distinct names, only ask for the 'name' property.
fetchRequest.resultType = NSDictionaryResultType;
fetchRequest.propertiesToFetch = [NSArray arrayWithObject:[[entity propertiesByName] objectForKey:@"name"]];
fetchRequest.returnsDistinctResults = YES;

// Now it should yield an NSArray of distinct values in dictionaries.
NSArray *dictionaries = [self.managedObjectContext executeFetchRequest:fetchRequest error:nil];
NSLog (@"names: %@",dictionaries);
15 голосов
/ 10 августа 2011

Вы пытаетесь использовать Базовые данные как процедурную базу данных, а не как диспетчер графов объектов, как предполагалось API, поэтому вы не найдете простого способа сделать это.

Нет прямого способа сделать это в Базовых данных, потому что Базовые данные связаны с объектами, а не со значениями. Поскольку управляемые объекты гарантированно являются уникальными, базовые данные не очень заботятся о значениях каждого объекта или о том, являются ли они дубликатами или значениями некоторых других объектов.

Чтобы найти уникальные значения:

  1. Выполнить выборку по определенному значению . Это даст вам массив словарей с ключом name и значением самой строки имени.
  2. Для возвращенного массива в (1) используйте оператор набора множеств для возврата набора уникальных значений.

Итак, что-то вроде:

NSSet *uniqueNames=[fetchedNameDicts valueForKeyPath:@"@distinctUnionOfSets.name"];

... который вернет набор объектов NSString с уникальным значением.

5 голосов
/ 10 октября 2011

Посмотрите на Извлечение значений определенных свойств , нет необходимости использовать Set для получения различных значений.

...