核心数据 - NSFetchedResultController按其他表字段对数据排序

时间:2015-01-02 07:03:32

标签: ios core-data nsfetchedresultscontroller nsfetchrequest nssortdescriptor

我有两张桌子 - 主人和细节 - 彼此相关(一位大师 - 许多细节)

我想显示来自Details表的记录列表,按"日期"排序Master表中的字段。

如何在以下代码中操纵NSSortDescriptor?或者对我的问题有任何其他建议吗?

代码:

NSFetchRequest *fr = [[NSFetchRequest alloc] init];
NSEntityDescription *e = [NSEntityDescription entityForName:@"Details"
                                     inManagedObjectContext:context];
[fr setEntity:e];

NSSortDescriptor *sd = [[NSSortDescriptor alloc]
                                       initWithKey:@"date" // ---- PROBLEM
                                         ascending:YES];

NSArray *arrSD = [[NSArray alloc] initWithObjects:sd, nil];
[fetchRequest setSortDescriptors:sortDescriptors];

self.frc = [[NSFetchedResultsController alloc]
                         initWithFetchRequest:fr
                         managedObjectContext:context
                           sectionNameKeyPath:nil
                                    cacheName:nil];

NSError *err;
[self.frc performFetch:&err];

现在,我希望数据按" date"进行排序。 - 字段,其为Master表的列名。

2 个答案:

答案 0 :(得分:1)

首先,您需要在主表和详细信息表之间设置关系。

然后您将能够在下一个方式使用您的排序说明中提交的其他表格。您的关系名称不能是一个集合(在一个主人 - 许多细节关系,您只能在您使用此类字段时为细节表创建排序描述符)

您的排序说明如下:

NSSortDescriptor *sd = [[NSSortDescriptor alloc]
                                       initWithKey:@"master.date"
                                         ascending:YES];

答案 1 :(得分:1)

我认为你缺少对Master in Details表的引用 即。

@interface Details : NSManagedObject

@property (nonatomic, retain) NSString * x;
@property (nonatomic, retain) NSString * y;
@property (nonatomic, retain) Master *master;

@end

这会将每个详细信息连接到一个且仅限主服务器。所以现在你可以实际获取按日期排序的详细信息:

NSFetchRequest *fr = [[NSFetchRequest alloc] init];
NSEntityDescription *e = [NSEntityDescription entityForName:@"Details"
                                     inManagedObjectContext:context];
[fr setEntity:e];

NSSortDescriptor *sd = [[NSSortDescriptor alloc]
                                       initWithKey:@ "master.date"
                                         ascending:YES];

享受。