2013-02-08 2 views
5

У меня серьезная проблема в моей базе данных CoreData. Я создал связь «Один ко многим» между двумя таблицами и добавил в таблицу добавленное свойство, содержащее все уникальные значения. Весь код работает, как ожидался в прошивке 5, но в IOS 6 я получаю следующее errror:Выбранная собственность работает в iOS5, но не iOS6

2013-02-08 15: 15: 49,382 ArdsBoroughCouncil [16152: c07] * Согласующий приложения из-за неперехваченное исключение ' NSUnknownKeyException ', причина: ' [< _NSObjectID_48_0 0xb25c3b0> valueForUndefinedKey:]: этот класс не соответствует ключевому значению для ключа tour_id. * Первый стек бросить вызов: (0x31c7012 0x24a3e7e 0x324ffb1 0x1c445ed 0x1bb08db 0x1bb088d 0x1bceb17 0x1bfe746 0x21b74bb 0x21b7176 0x21b6e44 0x21b66f4 0x21b2d63 0x21b2a82 0x21b2850 0x21b2625 0x21b1e07 0x21b18f4 0x21b0a6d 0x21ae9c9 0x2201276 0x227b155 0x2201071 0x2880014 0x286fd5f 0x286faa3 0x220103b 0x2200e9e 0x21ae9c9 0x2209dfa 0x22375cf 0x2237a03 0x59de1 0x11c2753 0x11c2a7b 0x11d0590 0x11d85bd 0x11d8eab 0x11d94a3 0x11d9098 0x1534da3 0x1526ad9 0x1526b54 0x24b7705 0x10e2920 0x10e28b8 0x11a3671 0x11a3bcf 0x11a2d38 0x111233f 0x1112552 0x10f03aa 0x10e1cf8 0x34b3df9 0x34b3ad0 0x313cbf5 0x313c962 0x316dbb6 0x316cf44 0x316ce1b 0x34b27e3 0x34b2668 0x10df65c 0x291d 0x2845) LibC++ abi.dylib : Terminate называется бросать исключение

предикат определен для извлеченной собственности является:

($ FETCH_SOURCE.tour_id == tour_id) И (! $ FETCH_SOURCE = SELF)

Я определил массив, чтобы вернуть все, чтобы получить все значения в моем классе Tour.

Знаете ли вы о каких-либо проблемах с выбранными свойствами wihtin iOS 6? Поскольку я не могу понять, что это работает без проблем в iOS 5, но не работает в iOS6.

Пожалуйста, смотрите весь другой связанный код ниже:

ниже код является, как я извлечение всех записей:

- (void)loadRecordsFromCoreData { 
    [self.managedObjectContext performBlockAndWait:^{ 
     [self.managedObjectContext reset]; 
     NSError *error = nil; 
     NSFetchRequest *request = [[NSFetchRequest alloc] init]; 
     NSEntityDescription *entityDescription = [NSEntityDescription entityForName:NSStringFromClass([Tour class]) inManagedObjectContext:self.managedObjectContext]; 
     [request setEntity:entityDescription]; 
     [request setResultType:NSManagedObjectResultType]; 
     [request setSortDescriptors:[NSArray arrayWithObject:[NSSortDescriptor sortDescriptorWithKey:@"tour_id" ascending:YES]]]; 
     self.tours = [self.managedObjectContext executeFetchRequest:request error:&error]; 
    }]; 

Код ниже обуви в NSManagedObjects я определил:

- Тур

#import <Foundation/Foundation.h> 
#import <CoreData/CoreData.h> 

@class TourDetail; 

@interface Tour : NSManagedObject 

@property (nonatomic, retain) NSNumber * tour_id; 
@property (nonatomic, retain) NSString * background_url; 
@property (nonatomic, retain) NSString * summary; 
@property (nonatomic, retain) NSString * title; 
@property (nonatomic, retain) NSSet *tourdetails_tour; 

@property (nonatomic, retain) NSArray *tourDetails; 
@end 

@interface Tour (CoreDataGeneratedAccessors) 

- (void)addTourdetails_tourObject:(TourDetail *)value; 
- (void)removeTourdetails_tourObject:(TourDetail *)value; 
- (void)addTourdetails_tour:(NSSet *)values; 
- (void)removeTourdetails_tour:(NSSet *)values; 

@end 
} 
#import "Tour.h" 
#import "TourDetail.h" 


@implementation Tour 

@dynamic tour_id; 
@dynamic background_url; 
@dynamic summary; 
@dynamic title; 
@dynamic tourdetails_tour; 
@dynamic tourDetails; 

@end 

- Подробности тура

#import <Foundation/Foundation.h> 
#import <CoreData/CoreData.h> 

@class Tour; 

@interface TourDetail : NSManagedObject 

@property (nonatomic, retain) NSNumber * id; 
@property (nonatomic, retain) NSNumber * tour_id; 
@property (nonatomic, retain) NSNumber * lattitude; 
@property (nonatomic, retain) NSNumber * longitude; 
@property (nonatomic, retain) NSString * audiofile; 
@property (nonatomic, retain) NSString * detail; 
@property (nonatomic, retain) NSString * title; 
@property (nonatomic, retain) Tour *tour_tourdetails; 

@end 

#import "TourDetail.h" 
#import "Tour.h" 


@implementation TourDetail 

@dynamic id; 
@dynamic tour_id; 
@dynamic lattitude; 
@dynamic longitude; 
@dynamic audiofile; 
@dynamic detail; 
@dynamic title; 
@dynamic tour_tourdetails; 

@end 

Любой совет, который вы можете предложить, был бы очень благодарен :) Как и любые примеры, которые могут возникнуть в отношении того, как лучше всего определить выбранные свойства?

Спасибо, Майкл

+0

только что из любопытства, как вы заполнили базу данных на первом месте и с помощью симулятора IOS 5? –

+0

Hi Space Dust Я заполнил db, используя объекты словаря mms, которые я затем сохранил с помощью модели. Это было сделано с использованием симулятора iOS5, но даже когда я пользуюсь симулятором ios6, данные сохраняются, но когда я пытаюсь восстановить мое импортированное свойство, исключение выбрасывается только с IOS6. У вас есть идеи по поводу того, что я могу решить эту проблему? –

+0

Привет, Майкл, вы нашли решение? У меня такие же проблемы. – epologee

ответ

0

код вашего использования здесь не является чистым

- (void)loadRecordsFromCoreData { 
    [self.managedObjectContext performBlockAndWait:^{ 
     [self.managedObjectContext reset]; 
     NSError *error = nil; 
     NSFetchRequest *request = [[NSFetchRequest alloc] init]; 
     NSEntityDescription *entityDescription = [NSEntityDescription entityForName:NSStringFromClass([Tour class]) inManagedObjectContext:self.managedObjectContext]; 
     [request setEntity:entityDescription]; 
     [request setResultType:NSManagedObjectResultType]; 
     [request setSortDescriptors:[NSArray arrayWithObject:[NSSortDescriptor sortDescriptorWithKey:@"tour_id" ascending:YES]]]; 
     self.tours = [self.managedObjectContext executeFetchRequest:request error:&error]; 
    }]; 

На самом деле, это немного сбивает с толку.

Вызов метода, который вызывает контекст управляемого объекта, который далее вызывает себя в синхронном блоке, который сбрасывается без причины, который устанавливает свойство self.tours вне блока. Все очень странно. Можете ли вы объяснить, почему вы это делаете?

Попробуйте это вместо этого.

+(void)loadRecordsWithCompletion:(void(^)(NSArray *records, NSError *error))completion { 
    NSManagedObjectContext *context; //Your context 
    NSError *error; 
    NSSortDescriptor *sortDesc = [NSSortDescriptor sortDescriptorWithKey:@"attribute" ascending:YES]; 
    NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:@"EntityName"]; 
    [request setSortDescriptors:@[sortDesc]]; 
    NSArray *records = [context executeFetchRequest:request 
               error:&error]; 
    completion(records, error); 
} 

 Смежные вопросы

  • Нет связанных вопросов^_^