将NSFetchedResultsController与属于实体的NSSet中的对象排序
我有一个名为Delivery
的对象,它有一组与其关联的Customer
对象。 每个Delivery对象还存储一个mainCustomerId
NSNumber*
的mainCustomerId
。 我有一个NSFetchedResultsController用于管理UITableView
的数据源。 问题是,我想通过Customer的lastName字段对NSFetchedResultsController进行排序(客户再次存储在Delivery
对象上称为customers
的多对多关系中),其中一个客户的customerId等于交货的MainCustomerId。
交付类看起来像这样(只有相关的部分)
@interface Delivery : NSManagedObject
@property (nonatomic, retain) NSNumber * mainCustomerId;
@property (nonatomic, retain) NSSet *customers;
@end
客户类看起来像这样
@interface Customer : NSManagedObject
@property (nonatomic, retain) NSNumber * customerId;
@property (nonatomic, retain) NSString * lastName;
// And the inverse relationship to the deliveries
@property (nonatomic, retain) NSSet *deliveries;
@end
我需要做一个NSSortDescriptor来做这样的事情(注意,我知道这是错误的格式,不会工作,但我希望它能传达这个想法)
NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"customers.AnyobjectInSet.lastName WHERE AnyobjectInSet.customerId == masterCustomerId ascending:YES];
我已经尝试了几个使用子查询和NSExpressions的东西,但总是不能使用任何使用Cocoa的功能(如使用@selector进行排序),因为它必须能够生成一个真正的mysql查询,而不需要Cocoa处理数据。 但我觉得有必要做这件事,因为这将是一个简单的查询在MySQL中。
select * from Delivery JOIN Customer ON Customer.customerId=Delivery.mainCustomerId ORDER BY Customer.lastName;
我试图避免在提取结果后排序,并将排序顺序存回对象(这很容易,但是我觉得这是错误的解决方案,因为我选择了相关的数据。必须有一种方法按它排序)。 任何帮助将超级赞赏。
提前致谢。
好吧,也许我错过了一些东西,但谓词建议对我来说非常有意义。 请纠正我,如果我错了,但(假设你知道mainCustomerID):
NSNumber *mainCustomerID = ...
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"customerID == %@", mainCustomerID];
NSSortDescriptor *sortDescriptor = [NSSortDescriptor sortDescriptorWithKey:@"lastName" ascending:YES];
NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:@"Customer"];
[request setPredicate:predicate];
[request setSortDescriptors:@[ sortDescriptor ]];
NSFetchedResultsController *controller = [[NSFetchedResultsController alloc] initWithFetchRequest:request ...
所以基本上如果它不清楚,这将获取customerID等于mainCustomerID的所有Customer记录,然后按lastName对这些结果进行排序。 这将在内部生成SQL语句来为您执行此操作。
这不是你想要做的吗?
另外,如果你想查看运行时由CoreData生成的SQL(有用的调试工具),打开你的方案并转到'参数'选项卡,并将以下内容添加到'在启动时传递的参数':
-com.apple.CoreData.SQLDebug 1
快乐编码:)
链接地址: http://www.djcxy.com/p/36177.html上一篇: Sort NSFetchedResultsController with object in NSSet belonging to entity
下一篇: NSSortDescriptor with Comparator Changes Behavior on Fetch vs Initial Load