首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >核心数据获取数据,这些数据实际上存储在persistentStore中,而不是实体的所有对象(persistentStored +最新创建的obj)

核心数据获取数据,这些数据实际上存储在persistentStore中,而不是实体的所有对象(persistentStored +最新创建的obj)
EN

Stack Overflow用户
提问于 2015-12-01 10:26:01
回答 1查看 44关注 0票数 0

我有一个实体名为 student ,我想获取生活在浦那市(城市== pune)的学生数据。桌子上有2学生,他们住在pune市

但在此之前,我已经创建了新的学生对象,他也住在浦那市。

因此,当我对学生实体发出获取请求时,它给了我3个学生数据,其中还包括我当前的学生数据(2个来自表,1个刚刚创建,没有保存在表中)

,所以我的问题是,我只想要那些实际存储在持久性数据中的学生数据,而不是那些刚刚创建的.

代码语言:javascript
复制
Entity data (student)
--------------------------------------------------------
student name       city         class
--------------------------------------------------------
Atul               pune           7
Sagar              mumbai         7
Ganesh             pune           7
--------------------------------------------------------

当前对象

代码语言:javascript
复制
Student * obj = [[Mlov alloc] initWithEntity:[NSEntityDescription entityForName:@"Student" inManagedObjectContext:self.managedObjectContext] insertIntoManagedObjectContext:self.managedObjectContext];


    obj.name = @"Nitin";
    obj.city = @"pune";
    obj.class = 10;
     NSError * error = nil;

    NSPredicate * pred = [NSPredicate predicateWithFormat:@"city == 'pune'"];


    NSFetchRequest * req = [[NSFetchRequest alloc] initWithEntityName:@"Student"];
    [req setReturnsObjectsAsFaults:NO];
    [req setPredicate:pred];
    NSError * error = nil;
    NSArray * result =[context executeFetchRequest:req error:nil];
    for (Student * obj in result)
    NSLog(@"%@",obj.name); 
代码语言:javascript
复制
Expected output as only 2 students data (Atul and Ganesh)

Actually giving output as 3 students data (Atual, Ganesh and Nitin)

我需要获取存储在持久性存储中的学生数据,如果您有任何建议,请告诉我。提前谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-12-01 10:57:55

解决方案1

您可以筛选出出现在上下文的insertedObjects属性中的对象。

代码语言:javascript
复制
[result filteredArrayUsingPredicate:[NSPredicate predicateWithFormat:@"NOT SELF IN %@",
                                                                     context.insertedObjects]];

解决方案2

对查询使用新的上下文。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34018035

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档