如何使用 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 从实体中选择所有行?的主要内容,如果未能解决你的问题,请参考以下文章

如何在 SQL 中将值显示为 Y 或 N?

如何使用scanf获取提示输入?

如何根据时间删除或查找文件

如何在第 n 次出现管道“|”后获取字符或字符串ORACLE 中使用 REGULAR_EXPRESSION 的符号?

Perl:如何将字符串的最后 n 位与 n 位或更多位连续匹配?

如何在不使用 cat -b 或 cat -n 选项的情况下打印文件内容以及行号[关闭]