2011-02-10 14 views
5

¿Cómo puedo comprobar si la base de datos de datos básicos está vacía? Traté:base de datos de datos básicos está vacío test

NSIndexPath *path1 = [NSIndexPath indexPathForRow:0 inSection:0]; 
NSManagedObject *managedObject = [self.fetchedResultsController objectAtIndexPath:path1]; 
if([[managedObject valueForKey:@"date"] description]!=nil){SOMEFUNCTION}else{SOMEFUNCTION} 

Gracias

Respuesta

18

usted tiene que crear un fetchrequest para cada entidad que se utiliza en los datos básicos. si la búsqueda de fetch regresa sin resultados, no tiene objetos de esta entidad almacenados en sus datos centrales.

- (BOOL)coreDataHasEntriesForEntityName:(NSString *)entityName { 
    NSFetchRequest *request = [[[NSFetchRequest alloc] init] autorelease]; 
    NSEntityDescription *entity = [NSEntityDescription entityForName:entityName inManagedObjectContext:self.managedObjectContext]; 
    [request setEntity:entity]; 
    [request setFetchLimit:1]; 
    NSError *error = nil; 
    NSArray *results = [self.managedObjectContext executeFetchRequest:request error:&error]; 
    if (!results) { 
     LogError(@"Fetch error: %@", error); 
     abort(); 
    } 
    if ([results count] == 0) { 
     return NO; 
    } 
    return YES; 
} 
1

no es perfecto lo admito pero funciona

mi código:

id <NSFetchedResultsSectionInfo> sectionInfo = [[self.fetchedResultsController sections] objectAtIndex:0]; 
    int fufu = [sectionInfo numberOfObjects]; 
    if(fufu!=0){DATABASE IS NOT EMPTY}else{DATABASE IS EMPTY} 

si alguien sabe que algo pls más Efectivas publicarla

+0

¿Por qué dice que esto no es perfecto? Funcionó para mí, pero ¿me estoy perdiendo es debilidad? –

+0

Simplemente no creo que sea la manera perfecta de hacerlo. pero estoy pasando, te ayudó – Csabi

0

Tengo estos dos métodos implementados en mi appDelegate:

- (NSString *)applicationDocumentsDirectory 

{ 

    NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES); 

    NSString *basePath = ([paths count] > 0) ? [paths objectAtIndex:0] : nil; 

    return basePath; 

} 

    - (NSPersistentStoreCoordinator *)persistentStoreCoordinator 

    { 

     if (persistentStoreCoordinator != nil) 

      return persistentStoreCoordinator; 

     NSURL *storeUrl = [NSURL fileURLWithPath: [[self applicationDocumentsDirectory] stringByAppendingPathComponent: @"YourApp.sqlite"]]; 

     NSLog(@"storeURL: %@", storeUrl); 

     NSError *error; 

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

     NSDictionary * options = [NSDictionary dictionaryWithObjectsAndKeys: 

           [NSNumber numberWithBool:YES], NSMigratePersistentStoresAutomaticallyOption, 

           [NSNumber numberWithBool:YES], NSInferMappingModelAutomaticallyOption, nil]; 

     if (![persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeUrl options:options error:&error]) 

     { 

      /* 
      Replace this implementation with code to handle the error appropriately. 

      abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be 
        useful during development. If it is not possible to recover from the error, display an alert panel that instructs the user to quit the application by pressing the Home button. 

      Typical reasons for an error here include: 
      * The persistent store is not accessible 
      * The schema for the persistent store is incompatible with current managed object model 
      Check the error message to determine what the actual problem was. 
      */ 


     }// if  

     return persistentStoreCoordinator; 
    } 

storeUrl imprime la ruta a la base de datos sqlite.

Si abre esta ruta con un administrador de sqlite, podrá ver el contenido de su base de datos sql. Yo uso este Gestor de SQLite para analizar bases de datos SQLite: SQLite Manager

(Sólo se puede utilizar este método en el simulador)

Cuestiones relacionadas