NSFetchRequest не удалось найти NSEntityDescription для имени сущности
Я пробовал предлагаемые решения для подобных вопросов на SO, но не повезло. Запрос выборки не может найти имя сущности "GarmentType".
вот моя модель данных :
ошибка возникает в executeFetchRequest в этой вспомогательной категории:
//
// GarmentType+Create.m
// Dressy
//
// Created by Michael Mangold on 9/4/13.
// Copyright (c) 2013 Michael Mangold. All rights reserved.
//
#import "GarmentType+Create.h"
@implementation GarmentType (Create)
// Creates or fetches a Core Data GarmentType entity.
+ (GarmentType *)garmentTypeWithName:(NSString *)name inManagedObjectContext:(NSManagedObjectContext *)context
{
NSLog(@"name:%@ context:%@",name,context);
GarmentType *garmentType = nil;
// Build fetch request.
NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:@"GarmentType"];
request.sortDescriptors = @[[NSSortDescriptor sortDescriptorWithKey:@"name" ascending:YES]];
request.predicate = [NSPredicate predicateWithFormat:@"name = %@",name];
// Execute fetch requesst.
NSError *error = nil;
NSArray *matches = [context executeFetchRequest:request error:&error]; // This is where it dies.
if (!matches || [matches count] > 1) {
NSLog(@"Error creating GarmentType.");
} else if ([matches count] == 0) {
garmentType = [NSEntityDescription insertNewObjectForEntityForName:@"GarmentType" inManagedObjectContext:context];
garmentType.name = name;
} else {
garmentType = [matches lastObject];
}
return garmentType;
}
@end
имя регистрирует правильное имя, а контекст не равен нулю.
помощник вызывается из UITableViewController IBAction, когда кнопка " готово нажата:
- (IBAction)handleDoneButton:(UIBarButtonItem *)sender
{
// Add garment type to core data.
[DressyHelper openDocumentUsingBlock:^(UIManagedDocument *document){
GarmentType *newGarment = [GarmentType garmentTypeWithName:self.garmentTypeNameTextField.text inManagedObjectContext:document.managedObjectContext];
NSLog(@"newGarment.name:%@",newGarment.name);
}];
[self dismissViewControllerAnimated:YES completion:nil];
}
newGarment.логи имен в порядке.
здесь .h для GarmentType:
#import <Foundation/Foundation.h>
#import <CoreData/CoreData.h>
@class Garment;
@interface GarmentType : NSManagedObject
@property (nonatomic, retain) NSString * name;
@property (nonatomic, retain) NSSet *garments;
@end
@interface GarmentType (CoreDataGeneratedAccessors)
- (void)addGarmentsObject:(Garment *)value;
- (void)removeGarmentsObject:(Garment *)value;
- (void)addGarments:(NSSet *)values;
- (void)removeGarments:(NSSet *)values;
@end
извинения за дамп кода, но я боролся с этим некоторое время. Изменение имени сущности приводит к той же ошибке, только с новым именем, как сущность не найдена.
инспектор для GarmentType:
и исключения:
2013-12-10 13:51:50.320 Dressy[4336:70b] name:asdf context:<NSManagedObjectContext: 0x8ad86f0>
2013-12-10 13:51:50.323 Dressy[4336:70b] *** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'NSFetchRequest could not locate an NSEntityDescription for entity name 'GarmentType''
*** First throw call stack:
(
0 CoreFoundation 0x017465e4 __exceptionPreprocess + 180
1 libobjc.A.dylib 0x014c98b6 objc_exception_throw + 44
2 CoreData 0x019b4b6e -[NSFetchRequest(_NSInternalMethods) _resolveEntityWithContext:] + 510
3 CoreData 0x019b34d6 -[NSManagedObjectContext executeFetchRequest:error:] + 70
4 Dressy 0x000051de +[GarmentType(Create) garmentTypeWithName:inManagedObjectContext:] + 510
5 Dressy 0x00002170 __54-[GarmentTypeAddTableViewController handleDoneButton:]_block_invoke + 208
6 Dressy 0x00006d51 __39+[DressyHelper openDocumentUsingBlock:]_block_invoke21 + 97
7 UIKit 0x00781f7b __59-[UIDocument saveToURL:forSaveOperation:completionHandler:]_block_invoke570 + 54
8 libdispatch.dylib 0x01e43440 _dispatch_barrier_sync_f_slow_invoke + 71
9 libdispatch.dylib 0x01e544b0 _dispatch_client_callout + 14
10 libdispatch.dylib 0x01e4275e _dispatch_main_queue_callback_4CF + 340
11 CoreFoundation 0x017aba5e __CFRUNLOOP_IS_SERVICING_THE_MAIN_DISPATCH_QUEUE__ + 14
12 CoreFoundation 0x016ec6bb __CFRunLoopRun + 1963
13 CoreFoundation 0x016ebac3 CFRunLoopRunSpecific + 467
14 CoreFoundation 0x016eb8db CFRunLoopRunInMode + 123
15 GraphicsServices 0x03a4d9e2 GSEventRunModal + 192
16 GraphicsServices 0x03a4d809 GSEventRun + 104
17 UIKit 0x00237d3b UIApplicationMain + 1225
18 Dressy 0x0000585d main + 141
19 libdyld.dylib 0x020e670d start + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException
(lldb)
ТИА
3 ответов
Я, наконец, нашел проблему. Этот.xcdatamodel не был включен в целевое членство. Выбор xcdatamodel на панели навигатора слева в Xcode, затем выбор первой вкладки (инспектор файлов) на панели утилиты справа, а затем выбор модели данных в разделе членство назначения устраняет проблему. Огромное спасибо всем, кто откликнулся.
диаграмма сущностей с именами сущностей - это только половина головоломки. Для каждой сущности, как вы определили имена классов? Именно это fetchRequestWithEntityName:
пойдет против.
EDIT:
поскольку имя класса разрешено, какое исключение вы получаете? После того, как вы продолжите, CoreData объясняет, в чем проблема? Действительно ли приложение аварийно завершает работу (я спрашиваю, потому что если у вас есть точка останова для исключений, основные данные часто будут бросать внутренние исключения, которые не имеют значения или вызывают сбой приложения)?
EDIT2:
авария не много сказать за нас, зная, что у вас есть действительный контекст. Следующим шагом было бы перечислить все сущности в точке останова, установленной непосредственно перед запросом выборки, используя код, например:
NSManagedObjectModel *managedObjectModel = [[context persistentStoreCoordinator] managedObjectModel];
NSDictionary *entities = [managedObjectModel entitiesByName];
NSArray *entityNames = [entities allKeys];
NSLog(@"All loaded entities are: %@", entityNames);
Я получил это после создания новой версии модели с новой сущностью, но забыл обновить URL-адрес файла данных:
NSURL *modelURL = [[NSBundle mainBundle] URLForResource:@"Data2.0" <==== Here
withExtension:@"mom"
subdirectory:@"Data.momd"];
_managedObjectModel = [[NSManagedObjectModel alloc] initWithContentsOfURL:modelURL];