I am working on an iPhone app, and in a particular view I need to load two different entities: One that will populate a UITableView
, and another that will populate a UITextView
.
Is it possible to fetch both properties using a single NSFetchedResultsController
?
Or do I need to use two different NSFetchedResultsController
s?
Any ideas on how to best approach this problem?
Each fetch request has only one entity and each fetched results controller has only one fetch. Therefore, you need separate controllers for each entity.
If you think about it, how would you make a predicate to fetch two logically separate entities?
You probably don't need two fetches at all. In most cases, you can fetch the entities that populate the table and then use a relationship for the entity of the selected row to populate something like a text view.
In your tableViewController, make a search bar with how many scopes you have.
When different scope is selected, you can fetch different entities!
This works because I made an app like this!
Users would have easier time separating the two different data too!
Best solution would be to refactor your Model and see if your 2 entities have something in common. You can make an abstract entity for the intersecting stuff, then inherit your 2 entities out of that. Perform the fetch on the abstract entity, and your fetch results controller should return mixed results.
As TechZen stated, the answer is no.
However, you can monitor the saves of the
NSManagedObjectContext
yourself and react to those saves. If you really do need to watch more than one entity (something that is far more common on the iPad than the iPhone) then add aNSNotification
observer on theNSManagedObjectContextDidSaveNotification
and look at the-userInfo
of theNSNotification
that comes back. You can then run predicates on against the results to determine if you need to update your display. That is what theNSFetchedResultsController
is doing under the covers.