2010-10-10 75 views
1

我正在使用核心数据,并且我定义了一个名为LogRecord的实体。在其他地方,这是填充了使用对象:核心数据中的空FetchedResultsController

 LogRecord *rec = [NSEntityDescription insertNewObjectForEntityForName:@"LogRecord" 
                 inManagedObjectContext:managedObjectContext]; 
     [rec timestampNow]; 

     rec.moodType = [NSNumber numberWithUnsignedInteger:i]; 
     rec.moodValue = value; 

     NSError *error = nil; 
     if (![rec.managedObjectContext save:&error]) { 
      [DataUtil displayFatalError:error message:@"Failed to save log entry"]; 
      errors++; 
     }   

我检查,并使用此代码后,底层SQLite数据库中有记录。

然而,当我尝试查询使用此数据:

- (NSFetchedResultsController *)fetchedResultsController { 
    if (fetchedResultsController == nil) { 

    NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init]; 

    NSEntityDescription *entity = [NSEntityDescription entityForName:@"LogRecord" 
               inManagedObjectContext:managedObjectContext]; 
    [fetchRequest setEntity:entity]; 

    NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"timestamp" ascending:NO]; 
    NSArray *sortDescriptors = [[NSArray alloc] initWithObjects:sortDescriptor, nil]; 
    [fetchRequest setSortDescriptors:sortDescriptors]; 

    // nil for section name key path means "no sections". 
    NSFetchedResultsController *aFetchedResultsController = 
     [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest 
              managedObjectContext:managedObjectContext 
               sectionNameKeyPath:nil 
                 cacheName:nil]; 
    aFetchedResultsController.delegate = self; 
    self.fetchedResultsController = aFetchedResultsController; 

    [aFetchedResultsController release]; 
    [fetchRequest release]; 
    [sortDescriptor release]; 
     [sortDescriptors release]; 
    } 

    return fetchedResultsController; 
}  

通过[[self.fetchedResultsController sections] count]返回零证明它配备了空。

任何想法我可能会调试呢?这是工作之前,我试图将此代码分解成不同的UIViewController ....

回答

7

没关系....不知怎的,在viewDidLoad [[self fetchedResultsController] performFetch:&error]的电话被删除。