Coredata Error ": <ошибкa>"

Я пытаюсь вытащить данные из CoreData с помощью следующего кода

NSFetchRequest *request = [[NSFetchRequest alloc] init];
request.entity = [NSEntityDescription entityForName:@"Cave" inManagedObjectContext:self.context];
request.predicate = [NSPredicate predicateWithFormat:@"(latitude > 0) AND (longitude > 0)"];

NSError *error;
NSLog(@"%@",[self.context executeFetchRequest:request error:&error]);
NSLog(@"%@",[error localizedDescription]);

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

2011-09-05 07:41:42.267 CaveConditions[6930:11903] (
    "<NSManagedObject: 0x7368060> (entity: Cave; id: 0x7367880 <x-coredata://C825FC9D-3490-4D8A-A811-979B819A2EB6/Cave/p31> ; data: <fault>)",
    "<NSManagedObject: 0x73547e0> (entity: Cave; id: 0x7356e20 <x-coredata://C825FC9D-3490-4D8A-A811-979B819A2EB6/Cave/p40> ; data: <fault>)",
    "<NSManagedObject: 0x73681e0> (entity: Cave; id: 0x7363e60 <x-coredata://C825FC9D-3490-4D8A-A811-979B819A2EB6/Cave/p42> ; data: <fault>)",
    "<NSManagedObject: 0x7368280> (entity: Cave; id: 0x7356be0 <x-coredata://C825FC9D-3490-4D8A-A811-979B819A2EB6/Cave/p72> ; data: <fault>)",
    "<NSManagedObject: 0x7368320> (entity: Cave; id: 0x733ad80 <x-coredata://C825FC9D-3490-4D8A-A811-979B819A2EB6/Cave/p73> ; data: <fault>)",
    "<NSManagedObject: 0x73683c0> (entity: Cave; id: 0x7333e70 <x-coredata://C825FC9D-3490-4D8A-A811-979B819A2EB6/Cave/p91> ; data: <fault>)",
    "<NSManagedObject: 0x7368480> (entity: Cave; id: 0x7361810 <x-coredata://C825FC9D-3490-4D8A-A811-979B819A2EB6/Cave/p101> ; data: <fault>)",
    "<NSManagedObject: 0x7368570> (entity: Cave; id: 0x7360110 <x-coredata://C825FC9D-3490-4D8A-A811-979B819A2EB6/Cave/p105> ; data: <fault>)",
    "<NSManagedObject: 0x7368610> (entity: Cave; id: 0x73303c0 <x-coredata://C825FC9D-3490-4D8A-A811-979B819A2EB6/Cave/p112> ; data: <fault>)"
)

Он работал нормально до штрафа, пока не сделал следующее изменение в Cave.m, которое является Entity

Я добавил MKAnnotation в качестве делегата в Cave.h и добавил этот код в Cave.m

- (CLLocationCoordinate2D)coordinate
{
    CLLocationCoordinate2D location;
    location.latitude = [self.latitude doubleValue];
    location.longitude = [self.longitude doubleValue];
    return location;
}

Есть ли способ отладить это?

Ответ 1

Это ожидаемое поведение, основные данные не возвратят полные объекты, пока вам не понадобится доступ к постоянным значениям объектов. Каждый из ваших возвращенных объектов будет "ошибкой" до этой точки.

Вы можете заставить запрос на выборку возвращать полные объекты с помощью [request setReturnsObjectsAsFaults:NO], но в большинстве случаев у вас будет хорошо. Посмотрите документацию для NSFetchRequest для получения дополнительной информации.

При обращении к одному из свойств основные данные перейдут в постоянное хранилище и извлекут остальные ваши значения, после чего вы получите полное описание в журналах.

Это кажется таким распространенным недоразумением, что я решил написать об этом, здесь.

Ответ 2

Я столкнулся с такой же проблемой, вытаскивая данные из CoreData! Итак, я последовал за инструкцией @jrturton, и я реализовал ее в Swift 3.

Шаг 1: Добавить import CoreData

Шаг 2: Добавьте код ниже..

let context = ( UIApplication.shared.delegate as! AppDelegate ).persistentContainer.viewContext
var request = NSFetchRequest<NSFetchRequestResult>()
request = Your_Entity_Name.fetchRequest()
request.returnsObjectsAsFaults = false
let arrayOfData = try context.fetch(request)

Надеюсь, это поможет вам.:)