Основные данные ios5: обновление nsfetchresultcontroller пригодно - PullRequest
0 голосов
/ 13 февраля 2012

Я работаю над приложением с основными данными и раскадровкой.приложение имеет uitabbarcontroller в качестве пользователя root.Я создал сущность и создал классы.Каждая вкладка имеет свой собственный контроллер навигации.представление на вкладке 1 просто сохраняет некоторые данные в базе данных из uilabels.и он работает нормально, и данные в базе данных.представление на вкладке 2 отображает данные из базы данных в uitableview.данные отображаются только когда я убиваю приложение и перезапускаю его.поэтому таблица пользовательского интерфейса не обновляется.Первый метод: я передал контекст управляемого объекта от делегата приложения в оба представления.Таким образом, пользовательский интерфейс не обновляется до тех пор, пока не будет перезапущен.Второй метод: я (неправильно) использовал делегат приложения, но все тот же результат.

MyApplicationDelegate *appDelegate = (MyApplicationDelegate *)[[UIApplication sharedApplication] delegate];

как можно добиться, чтобы одно представление только добавляло данные к основным данным (что оно делает прямо сейчас), а второепросматривать получать уведомления об изменениях и отображать их в uitableview?

edit

-(NSFetchedResultsController *) fetchedResultsController
{
if (__fetchedResultsController != nil) {
    return __fetchedResultsController;
}

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

NSEntityDescription *entity = [NSEntityDescription entityForName:@"Favis" inManagedObjectContext:self.managedObjectContext];
[fetchRequest setEntity:entity];

NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"chapterid" ascending:NO];
NSArray *sortDescriptors = [NSArray arrayWithObjects:sortDescriptor, nil];

[fetchRequest setSortDescriptors:sortDescriptors];

[NSFetchedResultsController deleteCacheWithName:@"Master"];
NSFetchedResultsController *aFetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:self.managedObjectContext sectionNameKeyPath:nil cacheName:@"Master"];
aFetchedResultsController.delegate = self;

self.fetchedResultsController = aFetchedResultsController;


NSError *error = nil;
if (![self.fetchedResultsController performFetch:&error]) {
    NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
    abort();
}

return __fetchedResultsController;
}

это код, когда вы используете шаблон основных данных.настроен только для работы с моим приложением.У меня это есть в моем обоих viewcontroller.

edit 2

Я реализовал nsfetchedresultcontroller в моем контроллере uitableview.управляемый объект возвращает точное количество данных в базе данных, но таблица пользовательского интерфейса не обновляется.я тоже сделал [self.tableview reloaddata] но не повезло

Ответы [ 2 ]

1 голос
/ 13 февраля 2012

В viewController с UITableVIew реализуйте методы для NSFetchedResultsControllerDelegate . В документации есть полная реализация этих методов.

А затем сделайте ваш viewController делегатом NSFetchedResultsController fetchedResultsController.delegate = self;

1 голос
/ 13 февраля 2012

На вкладке 2 должно быть что-то, чтобы уведомлять, как данные, измененные в базе данных, обновляют новые данные. Есть ли такие? Если

NSManagedObjectContext, NSFetchedResultsController на вкладке 2, сказав Реализуйте NSFetchedResultsController методы делегирования.

в приложении.

secTab.managedObjectContext = self.managedObjectContext;

Конечно, теперь это работает

...