web-dev-qa-db-ja.com

Coredataエラー「data:<fault>」

次のコードで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で次の変更を行うまで、以前は正常に動作していました

MKAnnotationをCave.hのデリゲートとして追加し、このコードをCave.mに追加しました

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

これをデバッグする方法はありますか?

102
Chris

これは予想される動作であり、オブジェクトの永続的な値にアクセスする必要があるまで、コアデータは完全なオブジェクトを返しません。返された各オブジェクトは、この時点まで「障害」になります。

[request setReturnsObjectsAsFaults:NO]を使用して、フェッチリクエストに完全なオブジェクトを強制的に返すことができますが、ほとんどの場合、問題はありません。詳細については、NSFetchRequestのドキュメントをご覧ください。

プロパティの1つにアクセスすると、コアデータが永続ストアに移動し、残りの値を取得すると、ログに完全な説明が表示されます。

これはよくある誤解のようで、私はそれについて書くことにしました here

266
jrturton

CoreDataからデータをプルしているときに同じ問題に直面しました!そこで、@ jrturtonが指示した方法に従って実装しましたSwift

ステップ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
do {
    let arrayOfData = try context.fetch(request)
} catch {
    // Handle the error! 
}

希望、それはあなたを助けるでしょう。 :)

2
roy