使用Linq在两个日期之间重叠记录

时间:2012-09-27 12:39:11

标签: c# linq date

在我的应用程序中,用户可以委派其他用户批准订单。

我需要验证的是,没有循环引用,因此如果User A在某段时间内被委派User B,则User B无法委托User A在该期间内的任何时间,即存在重叠(dd/mm/yyyy中的日期):

Delegator    Delegated To    DateFrom    DateTo
User A       User B          01/11/2012  08/11/2012
User A       User B          16/12/2012  24/12/2012

这是我必须检查重叠的代码:

var overlaps = .Session.QueryOver<DelegateOrderApproval>()
    .Where(x => x.DateFrom > DateTime.Now && delegateOrderApproval.DelegatedUser.UserId == x.DelegatorUser.UserId)
    .And(x => x.DateFrom >= delegateOrderApproval.DateFrom && delegateOrderApproval.DateTo <= x.DateTo
              || (x.DateFrom >= delegateOrderApproval.DateFrom && x.DateTo <= delegateOrderApproval.DateTo)
              || (x.DateFrom <= delegateOrderApproval.DateFrom && x.DateTo >= delegateOrderApproval.DateFrom)
              || (x.DateFrom <= delegateOrderApproval.DateFrom && x.DateTo >= delegateOrderApproval.DateTo))
    .List();

如果我尝试添加以下记录:

Delegator: User B
Delegated  To: User A
Date From: 15/11/2012
DateTo:    21/11/2012

应该没有冲突,因为User B不是该时间段内User A的代理人?它在12月份创下纪录。

我搜索了日期范围重叠代码并尝试了所有内容,但似乎没有任何工作。

有什么想法吗?

1 个答案:

答案 0 :(得分:1)

你不能简单地做

var doesOverlapExist = Session.QueryOver<DelegateOrderApproval>()
     .Any(x => 
        x.DateFrom > DateTime.Now && 
        delegateOrderApproval.DelegatedUser.UserId == x.DelegatorUser.UserId &&
        x.DateFrom <= delegateOrderApproval.DateTo &&
        x.DateTo >= delegateOrderApproval.DateFrom);

或如果您没有,请替换为

Where(x=> blabla).Count() >0

重叠检查逻辑: Determine Whether Two Date Ranges Overlap