繁体   English   中英

核心数据 - 查找具有重叠日期范围的记录

[英]Core Data - Finding records with overlapping date ranges

我正在开发一个带有Core Data的iOS应用程序,用于跟踪培训课程和相关数据的安排。 我的模型(SIMCourse)有两个属性 - startDateendDate是NSDate对象。 到现在为止还挺好。

我现在正在努力添加一项功能,以防止在同一时间安排两个课程。 因此,当我创建新的SIMCourse时,我想检查其日期范围是否与任何其他现有SIMCourse的日期范围重叠。 换句话说,如果我的新课程在1月1日至3日运行,并且我有一个运行在1月2日至4日的课程,那显然是一个冲突。

我知道我可以获取数据存储中的所有SIMCourse对象并遍历它们,但我完全不相信这是最好的方法。 谁能帮助我指出正确的方向?

(newStartDate, newEndDate)重叠(startDate, endDate) if

(newStartDate <= endDate) && (startDate <= newEndDate)

(这几乎是@Bergasms建议的,但不完全是。如果我在这里弄错了,应该归功于他。)

您可以使用以下获取请求来检查重叠课程:

NSDate *newStartDate = ...;
NSDate *newEndDate = ...;

NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:@"SIMCourse"];
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"(%@ <= endDate) AND (startDate <= %@)",
                                      newStartDate, newEndDate];
request.predicate = predicate;
NSArray *results = [context executeFetchRequest:request error:&error];
if (error == nil) {
    // handle error
} else if (results.count == 0) {
    // no overlapping entries
} else {
    //overlapping entries in results array
}

如果一门课程的结束日期等于另一门课程的开始日期,我假设这里有两门课程重叠。 如果这些间隔不被视为“重叠”,则可以在谓词中替换<= by <

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM