编程语言
首页 > 编程语言> > c# – 日期重叠的范围

c# – 日期重叠的范围

作者:互联网

我有两个包含日期的变量. DateStart和DateEnd(在SQL中).
我还有两个DatePicker控件(在WinForm中).
我从数据库导入两个日期,需要做一些棘手的事情.

因此,这两个变量创建了一系列日期,两个日期选择器创建了另一个日期范围.
如何检查这些日期范围是否与Sql查询重叠?

例如(yyyy / mm / dd格式)

DateStart = 2012/07/01,DateEnd = 2012/07/31

| DatePicker1  | DatePicker2 | Overlapping | 
--------------------------------------------
| 2012/07/15   | 2012/07/16  |    True     |
--------------------------------------------
| 2012/07/31   | 2012/08/01  |    True     |
--------------------------------------------
| 2012/06/20   | 2012/07/01  |    True     |
--------------------------------------------
| 2012/08/01   | 2012/09/01  |    False    |
--------------------------------------------

我知道这有点乱,但我不知道怎么回答这个问题.

解决方法:

如果第一范围的开始在第二范围的结束之前并且第一范围的结束在第二范围的开始之后,则两个日期范围重叠.所以:

where DateStart <= @DatePicker2
  and DateEnd >= @DatePicker1

A good explanation is this way.

标签:c,sql-server-2008,date-range
来源: https://codeday.me/bug/20190630/1332334.html