Core Data: Keypath Error Not Found in Entity <NSSQLEntity Studies id=3>

你离开我真会死。 提交于 2019-12-21 07:08:51

问题


Could any one tell me what's the wrong with this code? It raises the following error and cause application to crash:

reason: 'keypath Studies.patients.PatientName not found in entity <NSSQLEntity Studies id=3>'

Code:

 - (void)viewDidLoad {
        [super viewDidLoad];

        test_coredataAppDelegate *appDelegate = (test_coredataAppDelegate *)[[UIApplication sharedApplication] delegate];
        self.context = appDelegate.managedObjectContext;


        NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
        NSEntityDescription *entity = [NSEntityDescription 
                                       entityForName:@"Studies" inManagedObjectContext:_context];
        [fetchRequest setEntity:entity];
        /**/
        NSLog(patientName);
        [fetchRequest setPredicate:[NSPredicate predicateWithFormat:
                               @"(Studies.patients.PatientName == %@ )",patientName]];



        NSError *error;
        self.StudiessList = [_context executeFetchRequest:fetchRequest error:&error];
        self.title = @"patients"; 
        [fetchRequest release];

    }

回答1:


Firstly, since your fetch entity is Studies you don't include it in the predicate because the Studies objects are the ones receiving the predicate test in the first place. So your predicate should be at least just:

patients.PatientName == %@

However, by convention, patients would indicate a to-many relationship. If so, that means that the actual value of patients is a set of (presumably) Patient objects. As such you can't ask a set for an attribute value as above: Instead you have to ask for a new set of all object in the set that match the predicate. Use the ANY or All operator like so:

ALL patients.PatientName == %@

I would add that by convention all attribute and relationship names start with lower case letters so if PatientName is an attribute it should be patientName.




回答2:


Either the Studies entity does not have a patient property, or whatever entity the patients relationship points to does not have a PatientName property (pay attention to upper/lowercase issues) or both.




回答3:


Usually when I see this error it means that I added a new Version to my Model but forgot to update the Current Model Version for the project.

Posting this answer to help my future self because it's not the first time I have landed on this page!



来源:https://stackoverflow.com/questions/5182969/core-data-keypath-error-not-found-in-entity-nssqlentity-studies-id-3

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!