如何使用 NSFetchedRequest 或 NSPredicate 从实体中选择所有行?
Posted
技术标签:
【中文标题】如何使用 NSFetchedRequest 或 NSPredicate 从实体中选择所有行?【英文标题】:How to select all the rows from an entity with NSFetchedRequest or NSPredicate? 【发布时间】:2012-01-11 13:46:04 【问题描述】:我对 Core Data 非常陌生,但我仍然对它及其所有可能性感到困惑。
我的模型中有一个表 USER,我想以“SELECT * FROM USER”的形式获取所有行。
实现这一目标的最佳方法是什么?
非常感谢您的帮助。
【问题讨论】:
【参考方案1】:使用 [NSPredicate predicateWithValue:YES] 全选。
【讨论】:
【参考方案2】:来自NSFetchRequest
文档:
如果您不指定谓词,则选择指定实体的所有实例(受其他约束,请参阅 executeFetchRequest:error: 了解完整详细信息)。
【讨论】:
【参考方案3】:基本的提取操作是这样的:
NSEntityDescription *entity = [NSEntityDescription entityForName:theEntityName inManagedObjectContext:_context];
NSFetchRequest *request = [NSFetchRequest new];
[request setEntity:entity];
您可以在此阶段使用 NSSortDescriptor 应用排序。
然后你获取所有实体:
NSError *error;
NSMutableArray *fetchResults = [[_context executeFetchRequest:request error:&error] mutableCopy];
【讨论】:
在 fetchResults 中将是实体对象,不是吗? 正确!它们是正确类型的实体。以上是关于如何使用 NSFetchedRequest 或 NSPredicate 从实体中选择所有行?的主要内容,如果未能解决你的问题,请参考以下文章
如何在第 n 次出现管道“|”后获取字符或字符串ORACLE 中使用 REGULAR_EXPRESSION 的符号?