使用 FetchedResultsController 按日期对核心数据进行排序
Posted
技术标签:
【中文标题】使用 FetchedResultsController 按日期对核心数据进行排序【英文标题】:Core Data Sort By Date With FetchedResultsController into sections 【发布时间】:2012-07-11 01:54:09 【问题描述】:我目前有一个类,其中包含一个日期对象。此日期对象包含时间和日期。所有这些信息都通过NSFetchedResultsController
加载到UITableViewCell
。我需要将日期分类为各个部分,其中每个部分都是日期没有时间。我还需要按时间对每个部分进行排序。这是我当前的 _fetchedResultsController 的样子:
[self.managedObjectContext lock];
NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
NSEntityDescription *entity = [NSEntityDescription
entityForName:@"Entity" inManagedObjectContext:self.managedObjectContext];
[fetchRequest setEntity:entity];
NSSortDescriptor *sort = [[NSSortDescriptor alloc]
initWithKey:@"due" ascending:YES];
[fetchRequest setSortDescriptors:[NSArray arrayWithObject:sort]];
[fetchRequest setFetchBatchSize:20];
NSFetchedResultsController *theFetchedResultsController =
[[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest
managedObjectContext:self.managedObjectContext sectionNameKeyPath:nil
cacheName:@"Root"];
theFetchedResultsController.delegate = sender;
[self.managedObjectContext unlock];
return theFetchedResultsController;
我需要排序的属性是Entity.due
属性。
【问题讨论】:
你能获取 NSDate 对象并将它们显示在你的 UITableView 中吗?换句话说,问题只是显示和排序吗? @Jamie 按日期将它们分类成部分只是一个问题(忽略小时、分钟和秒) 【参考方案1】:您可能想查看名为“DateSectionTitles”的核心数据示例以获得更多信息,我将重点介绍其中的基础知识。
要根据日期划分部分,您需要首先按标准化(或简化)日期进行排序。请尝试以下操作:
在核心数据模型编辑器中为您的实体添加一个瞬态属性。确保它的类型是 NSDate 并且检查了它的瞬态属性。通过将属性添加为强 NSDate 来更新您的 NSManagedObject 类文件。称之为“simplifiedDate”。还将另一个属性添加到您的 .h 文件中,称为“primitiveSimplifiedDate”。让它变得强大。
在 .m 中,对简化日期和原始简化日期都使用 @dynamic。此瞬态属性应使用返回已标准化为午夜的 NSDate。此级别设置所有内容并允许您建立部分。我已经使用了这样的代码:
-(NSDate *)simplifiedDate
// Create and cache the section identifier on demand.
[self willAccessValueForKey:@"simplifiedDate"];
NSDate *tmp = [self primitiveSimplifiedDate];
[self didAccessValueForKey:@"simplifiedDate"];
if (!tmp)
tmp=[self simplifiedDateForDate: [self due]];
[self setPrimitiveSimplifiedDate: tmp];
return tmp;
-(NSDate *)simplifiedDateForDate:(NSDate *)date
if (!date)
return nil;
static NSCalendar *gregorian = nil;
gregorian=[[NSCalendar alloc] initWithCalendarIdentifier:NSGregorianCalendar];
NSDateComponents *newDateComponents=[gregorian components:(NSYearCalendarUnit | NSMonthCalendarUnit| NSDayCalendarUnit) fromDate:date];
return [gregorian dateFromComponents:newDateComponents];
如果您愿意,这也可以是在设置实际日期时计算和存储的实际属性。
接下来,您将拥有两个排序描述符。第一个排序描述符将是上述瞬态属性“simplifiedDate”。第二个属性是“due”属性。 “simplifiedDate”,只要在下一步中正确设置了 NSFetchedResultsController,就会根据部分对所有内容进行排序。
最后,您需要在分配/初始化 NSFetchedResultsController 时提供节键名称。在这种情况下,它将是“simplifiedDate”。像这样:
NSFetchedResultsController *theFetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest
managedObjectContext:self.managedObjectContext sectionNameKeyPath:@"simplifiedDate"cacheName:@"Root"];
希望这会有所帮助。
t
【讨论】:
那么我会在子类中添加一个新属性并添加这个方法吗?我将如何使财产和新方法一起工作?属性的属性应该是什么样的(强、弱、非原子、NSDate、动态等)。谢谢 谢谢,有机会我会试试看是否有效 没有可见的接口声明选择器'primitiveSimplifiedDate'是我在[self primitiveSimplifiedDate]方法调用中遇到的错误 请添加primitiveSimplifiedDate作为属性,见上面更新的代码。 我收到错误 *** 由于未捕获的异常“NSInvalidArgumentException”而终止应用程序,原因:“在实体以上是关于使用 FetchedResultsController 按日期对核心数据进行排序的主要内容,如果未能解决你的问题,请参考以下文章
在使用加载数据流步骤的猪中,使用(使用 PigStorage)和不使用它有啥区别?
Qt静态编译时使用OpenSSL有三种方式(不使用,动态使用,静态使用,默认是动态使用)