2012-07-07 13 views
8

IOS icloudNSInternalInconsistencyException (error durante la ejecución de la cadena SQL 'INSERT INTO Y_UBMETA (YPEERID, YTRANSACTIONNUMBER))

Terminación de aplicación debido a excepción no detectada 'NSInternalInconsistencyException', razón:' error durante la ejecución de la cadena SQL 'INSERT INTO Y_UBMETA (YPEERID, YTRANSACTIONNUMBER)

error error no resuelto dominio = Código NSCocoaErrorDomain = 134312 recuperación tienda metadatos" parece haber fracasado, por favor, trate de añadir la tienda para el coordinador de nuevo. Si esto no funciona, migrar los datos a un nuevo persistente ubiquitized almacenar." UserInfo = 0xdba5b80 {NSLocalizedDescription = La recuperación de los metadatos de la tienda parece haber fallado, intente agregar la tienda al coordinador nuevamente. Si eso no funciona, migre los datos a un nuevo almacén persistente ubiquitizado.}, { NSLocalizedDescription = "La recuperación de los metadatos de la tienda parece haber fallado. Intente agregar nuevamente el almacén al coordinador. Si eso no funciona, migre los datos a un nueva tienda persistente ubiquitizada. ";

¿Cómo resuelvo este problema? Porque es una consulta interna para iCloud. Estoy poniendo mi bloque de código siguiente del método que he escrito ..

- (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_; 
} 

Respuesta

0

Tengo el mismo problema, sucedió porque he cambiado el atributo del modelo de datos de Xcode, no desde mi aplicación por código. Lo resolví borrando el archivo SQLite de iCloud y borré la aplicación del dispositivo y luego reconstruí. Funcionó para mí

Cuestiones relacionadas