获取电影租赁的日期范围

时间:2015-09-07 10:49:47

标签: c# asp.net linq linq-to-sql

我有一个电影租赁应用程序。该公司将进入电影租赁日期和电影租赁结束日期。日期可以重叠(因为您可以拥有许多客户)。数据库中的数据存储为

RecordID    FromRentDate            ToRentDate
   1      2016-10-06 18:00:00.000   2016-10-06 20:00:00.000
   2      2015-10-06 18:00:00.000   2015-10-06 20:00:00.000 
   3      2015-09-29 16:00:00.000   2015-09-30 17:00:00.000 
   4      2015-09-11 00:00:00.000   2015-09-11 00:00:00.000 
   5      2015-09-09 10:00:00.000   2015-09-09 14:30:00.000 

当用户选择日期(使用标准.Net控件)时,将调用以下代码

        IEnumerable<Event> LiveDates = DataContext.Events.Where(d => d.StartDate.Value >= DateTime.Now);
        IEnumerable<DateTime> AllLiveDates = null;

        if (LiveDates != null && LiveDates.Count() > 0)
        {
            DateTime FromRentDate = LiveDates.Where(f => f.StartDate.HasValue).Min(f => f.StartDate).Value;
            DateTime ToRentDate = LiveDates.Where(t => t.EndDate.HasValue).Max(f => f.EndDate).Value;

            AllLiveDates = Enumerable.Range(0, int.MaxValue)
                         .Select(x => FromRentDate.Date.AddDays(x))
                         .TakeWhile(x => x <= ToRentDate.Date)
                         .Where(x => DataContext.Events.Any(c => x >= c.StartDate && x <= c.EndDate));
        }

        return AllLiveDates.ToList();

我想要发生的是当用户选择一个日期时,它会从所选日期到结束日期的所有日期,包括电影也在外的所有包含日期​​,所以使用上述数据,如果我选择今天的日期我应该回来所有记录,日期应该列为:

2015-09-09
2015-09-11
2015-09-29
2015-09-30
2015-10-06 .... etc

请注意2015-09-292015-09-30是如何被包含但2015-09-30 的开始日期。这是因为这部电影的租期为2天(9月29日和30日)。

我遇到上述代码的问题是它只返回1个日期。调试它似乎进入AllLiveDates代码,有些东西正在删除其他日期,但不知道是什么?

2 个答案:

答案 0 :(得分:2)

你可以试试这样的事情

var dateList = new List<DateTime>();
foreach (var ld in LiveDates)
{
    for (var dt = ld.StartDate.Date; dt <= ld.EndDate.Date; dt = dt.AddDays(1))
    {
        dateList.Add(dt);
    }
}
dateList = dateList.Distinct().ToList();
dateList = dateList.Sort((a, b) => a.CompareTo(b));

答案 1 :(得分:1)

问题似乎是您要将日期值与日期和时间进行比较。

以日期2015-09-09为例。当您将其与表格中的DateTime值进行比较时,您应获得零匹配,因为DateTime2015-09-09 00:00:00.0000不在任何值的DateTime值之间您的数据点。

您需要删除数据点的时间部分,以使比较按您希望的方式工作。幸运的是LINQ to SQL支持.Date值的DateTime属性,所以这应该有效:

试试这个:

AllLiveDates = Enumerable.Range(0, int.MaxValue)
    .Select(x => FromRentDate.Date.AddDays(x))
    .TakeWhile(x => x <= ToRentDate.Date)
    .Where(x => DataContext.Events.Any(c => x >= c.StartDate.Value.Date && x <= c.EndDate.Value.Date));

只是不要看生成的SQL ......它不漂亮。