标签: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. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。