views:

295

answers:

3

Hi,

The situation:

I fetch a complete table from my sqllite core data database and show it in a TableView like this:

NSEntityDescription *entity = [NSEntityDescription entityForName:@"MyTable"
                                          inManagedObjectContext:managedObjectContext];

The Challenge:

How do I get the EntryID and fetch the specific entry from the database (e.g. if i click on an entry)? I think this goes in the right direction?

NSPredicate *predicate = [NSPredicate predicateWithFormat: @"(id = %@)", myEntryID];
A: 

You might want to look at -[NSManagedObject objectID] and -[NSManagedObjectContext objectWithID:].

Ben Gottlieb
+1  A: 

When you build the table you do so either with an array returned by a fetch or by the implicit array inside a NSFetchResultsController. Therefore, the object you want has the same index in the array/controller as it does in the table.

So, it becomes simply a matter of calling:

myObject=[fetchedArray objectAtIndex:tableRowIndex];

or

myObject=[myFetchedResultsController objectAtIndexPath:tableRowIndex];

This is the real genius of the UITable. It always reflects the data model precisely. You never have to translate back and forth between the table indexes and your data model indexes.

TechZen
+2  A: 

If you have an entry object called entry, it would be a predicate like this:

NSPredicate *predicate = [NSPredicate predicateWithFormat: @"(SELF = %@)", entry];

Which is roughly equivalent to

NSPredicate *predicate = [NSPredicate predicateWithFormat: @"(objectID = %@)", entry.objectID];

For a NSManagedObjectID, you get something like:

NSPredicate *predicate = [NSPredicate predicateWithFormat: @"(objectID = %@)", myEntryID];
MrMage
+1 If you have to use a predicate, this is the way to go. Otherwise, `-[NSManagedObjectContext objectWithID:]` would probably be better.
Dave DeLong
Of course, but for e.g. `NSFetchedResultsController` you have to use a predicate.
MrMage