ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

c# – 日期重叠的范围

2019-06-30 02:56:24  阅读:158  来源: 互联网

标签:c sql-server-2008 date-range


我有两个包含日期的变量. 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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有