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

Posted

技术标签:

【中文标题】核心数据 - 查找具有重叠日期范围的记录【英文标题】:Core Data - Finding records with overlapping date ranges 【发布时间】:2012-10-09 05:54:59 【问题描述】:

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

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

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

【问题讨论】:

我无权获得正确的语法,但听起来你只想要一个 NSPredicate 对象与 ((endDate > newStartDate and startDate newEndDate) 或 (startDate newEndDate))。为了不那么冗长,您还可以选择所有不符合 (endDate newEndDate) 的对象,但这需要一些改进。 Martin,您的回答正是我所需要的。非常感谢! 【参考方案1】:

(newStartDate, newEndDate)(startDate, endDate) 如果重叠

(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

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

【讨论】:

以上是关于核心数据 - 查找具有重叠日期范围的记录的主要内容,如果未能解决你的问题,请参考以下文章

MySQL-查找具有重叠期间的记录

如何使用开始和结束日期时间在司机的行程中查找重叠记录

将具有单独日期范围的表格组合在一起而不重叠数据 - Access

查找不同行中日期时间间隔的重叠?

在 oracle SQL 中基于重叠日期范围连接客户端记录

SQL 重叠日期范围