我需要定义用户日期范围与存储在数据库中的任何其他日期范围相交(开始日期和结束日期字段)。例如数据库值
StartDate | EndDate
2015-01-01 | 2015-01-30
2015-02-01 | 2015-02-25
用户输入StartDate: 2015-01-12 EndDate 2015-02-13.
我需要找出用户范围被占用。可以用一个 LINQ 查询来做吗?
我认为你可以像这样使用查询:
bool overlap = collection.Any(x=>(x.StartDate <= EndDate)&&(x.EndDate >= StartDate));
当然,您需要将集合更改为数据库集合(这取决于您使用的数据库框架)
它将确定是否有任何开始日期和结束日期对在提供的两个日期(开始日期和结束日期)之间开始和结束。