8

iOS iCloud

キャッチされなかった例外によるアプリの終了'NSInternalInconsistencyException'、理由:'SQL文字列の実行中にエラーが発生しました'INSERT INTO Y_UBMETA(YPEERID、YTRANSACTIONNUMBER)

未解決のエラーエラードメイン=NSCocoaErrorDomainコード=134312「ストアのメタデータの回復に失敗したようです。ストアをコーディネーターに再度追加してみてください。それが失敗した場合は、データを新しいユビキタス化された永続ストアに移行してください。」UserInfo = 0xdba5b80 {NSLocalizedDescription=ストアのメタデータの回復に失敗したようです。ストアをコーディネーターに再度追加してみてください。それが失敗した場合は、データを新しいユビキタス化された永続ストアに移行します。}、{NSLocalizedDescription = "ストアメタデータのリカバリが失敗したようです。ストアをコーディネーターに再度追加してみてください。それが失敗した場合は、データを新しいに移行してください。ユビキタス化された永続ストア。";

この問題を解決するにはどうすればよいですか?それがiCloudの内部クエリであることをCoz。私が書いたメソッドの下にコードブロックを置いています。

    - (NSPersistentStoreCoordinator *)persistentStoreCoordinator
 {
     NSLog(@"persistentStoreCoordinator:%@",[persistentStoreCoordinator_ description]);
     if((persistentStoreCoordinator_ != nil)) 
     {
         return persistentStoreCoordinator_;
     }

     NSLog(@"persistentStoreCoordinator:%@",[persistentStoreCoordinator_ description]);
     NSURL *storeURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:@"CoreDataModel.sqlite"];

     persistentStoreCoordinator_ = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:[self managedObjectModel]];


     NSPersistentStoreCoordinator* psc = persistentStoreCoordinator_;

     NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
    
             
         dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
         NSFileManager *fileManager = [NSFileManager defaultManager];

         // Migrate datamodel
         NSDictionary *options = nil;

         // this needs to match the entitlements and provisioning profile
         NSURL *cloudURL = [fileManager URLForUbiquityContainerIdentifier:nil];

         NSLog(@"cloudURL:%@",cloudURL);

             //NSString* coreDataCloudContent = [[cloudURL path] stringByAppendingPathComponent:@"Data"];  
             
            cloudURL = [cloudURL URLByAppendingPathComponent:@"Data"];                                                                                                                                   

        // NSLog(@"coreDataCloudContent:%@",coreDataCloudContent);


        //if ([coreDataCloudContent length] != 0 && [[defaults objectForKey:@"allMetadataFlag"] isEqualToString:@"YES"]) 
             
        if (cloudURL )//&& [[defaults objectForKey:@"allMetadataFlag"] isEqualToString:@"YES"])
             
         {
             // iCloud is available
            // cloudURL = [NSURL fileURLWithPath:coreDataCloudContent];

             NSLog(@"cloudURL:%@",cloudURL);

             options = [NSDictionary dictionaryWithObjectsAndKeys:
                        [NSNumber numberWithBool:YES], NSMigratePersistentStoresAutomaticallyOption,
                        [NSNumber numberWithBool:YES], NSInferMappingModelAutomaticallyOption,
                        @"SecureAssistant.store", NSPersistentStoreUbiquitousContentNameKey,
                        cloudURL, NSPersistentStoreUbiquitousContentURLKey,nil];
         } 
         else 
         {
             // iCloud is not available
             options = [NSDictionary dictionaryWithObjectsAndKeys:
                        [NSNumber numberWithBool:YES], NSMigratePersistentStoresAutomaticallyOption,
                        [NSNumber numberWithBool:YES], NSInferMappingModelAutomaticallyOption,nil];
         }
             NSError *error = nil;
         [psc lock];
         if (![psc addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeURL options:options error:&error])
         {
             NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
             abort();
         }
         [psc unlock];

         dispatch_async(dispatch_get_main_queue(), ^{
             NSLog(@"asynchronously added persistent store!");
             [[NSNotificationCenter defaultCenter] postNotificationName:@"RefetchAllDatabaseData" object:self userInfo:nil];
         });

     });
    
    return persistentStoreCoordinator_;
 }
4

1 に答える 1

0

コードでアプリからではなく、Xcode から datamodel の属性を変更したために、同じ問題が発生しました。iCloudからSQLiteファイルを削除し、デバイスからアプリを削除してから再構築することでこれを解決しました。それは私のために働いた。

于 2012-10-18T13:00:18.620 に答える