Core Data NSPredicate to filter results
- by Bryan
I have a NSManagedObject that contains a bID and a pID. Within the set of NSManagedObjects, I only want a subset returned and I'm struggling to find the correct NSPredicate or way to get what I need out of Core Data.
Here's my full list:
bid pid
41 0
42 41
43 0
44 0
47 41
48 0
49 0
50 43
There is a parent-child relationship above.
Rules:
If a record's PID = 0, it means that that record IS a parent record.
If a record's PID != 0, then that record's PID refers to it's parent record's BID.
Example:
1) BID = 41 is a parent record. Why? Because records BID=42 and record BID=47 have PID's of 41, meaning those are children of its PID record.
2) BID = 42 has a parent record with a BID = 41.
3) BID = 43 is a parent record.
4) BID = 44 is a parent record.
5) BID = 47 has a parent record with a BID = 41 because its PID = 41. See #1 above.
6) BID = 48 is a parent record.
7) BID = 49 is a parent record.
8) BID = 50 is a child record, and its parent record has a BID = 43.
See the pattern?
Now, basically from that, I want only the following rows fetched:
bid pid
44 0
47 41
48 0
49 0
50 43
BID = 41, BID = 48, BID = 49 should all be returned because there are no records with a PID equal to their BID.
BID = 47 should be returned because it is the most recent child of PID = 41.
BID = 50 should be returned because it is the most recent child of PID = 43.
Hope this helps explain it more.