私はアプリケーションでCoreDataを使用していますが、これは1対多の関係であり、とという2つのエンティティがfolders
ありfiles
ます。したがって、フォルダには多くのファイルを含めることができます。したがって、最初のView Controllerにはすべてのフォルダーが表示され、各フォルダーをクリックすると、そこに存在するファイルが表示されます。
これで、そこに存在するすべてのフォルダーとファイルはユーザーによって動的に作成され、データベースやWebサーバーからのものではありません。
これで、アプリデリゲートから開いたView Controllerがもう1つあります。ここで、いくつかのファイルを表示します。
managedObjectContext
まず、アプリデリゲートで宣言されるを渡す必要があることを知っています
ViewController *View = [[ViewController alloc]initWithNibName: @"ViewController" bundle:nil]
View.managedObjectContext = self.managedObjectContext;
したがって、を渡すだけmanagedObjectContext
で、ファイルエンティティオブジェクトにアクセスできますか、またはファイルエンティティオブジェクトも渡す必要があります。
ご存知のように、とという2つのエンティティがFolder
ありFile
、任意のフォルダに保存されているファイルにアクセスするために、これを実行します。
NSMutableArray *filesArray = [self.folder.file mutableCopy];
しかし今、私は必要なanyViewにファイルを表示したいと思います。これは、2つの3つのナビゲーションの後に開くか、appDelegate.mから直接開くことができます。
非常に明確にするために、私の質問はこれをどのように行うかです。つまり、からfilesArrayを取得するにはどうすればよいですかAppDelegate
。
以下の回答に基づいて編集されました。この方法でfetchResultsControllerを作成しました
- (NSFetchedResultsController *)fetchedResultsController {
if (m_fetchResultsController != nil) {
return m_fetchResultsController;
}
NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
// Edit the entity name as appropriate.
NSEntityDescription *entity = [NSEntityDescription entityForName:@"File" inManagedObjectContext:self.managedObjectContext];
[fetchRequest setEntity:entity];
// Set the batch size to a suitable number.
[fetchRequest setFetchBatchSize:20];
// Edit the sort key as appropriate.
NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"alarm" ascending:YES];
NSArray *sortDescriptors = [NSArray arrayWithObjects:sortDescriptor, nil];
[fetchRequest setSortDescriptors:sortDescriptors];
[fetchRequest setPredicate:[NSPredicate predicateWithFormat:@"alarm!= nil"]];
// Edit the section name key path and cache name if appropriate.
// nil for section name key path means "no sections".
NSFetchedResultsController *aFetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:self.managedObjectContext sectionNameKeyPath:nil cacheName:nil];
aFetchedResultsController.delegate = self;
self.fetchResultsController = aFetchedResultsController;
NSError *error = nil;
if (![self.fetchResultsController performFetch:&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.
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
abort();
}
return m_fetchResultsController;
}
そしてViewDidLoadで私はこのように書いた
- (void)viewDidLoad
{
[super viewDidLoad];
NSError *error;
if (![[self fetchedResultsController] performFetch:&error]) {
// Update to handle the error appropriately.
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
exit(-1); // Fail
}
NSMutableArray *alarms = [[self.fetchResultsController fetchedObjects]mutableCopy];
NSLog(@"alarmsCount:%d",[alarms count]);
}
よろしくランジット。