现在的位置: 首页 > 综合 > 正文

在SQL中,对时间区间的检查精度进行配置查询

2012年09月13日 ⁄ 综合 ⁄ 共 624字 ⁄ 字号 评论关闭

输入的比较精度:@datepart

(@datepart 参数参阅:http://msdn.microsoft.com/zh-cn/library/ms174420.aspx

输入时间范围:@Start datetime, @End datetime

数据库的时间值:Date

核心语句:
datediff(@datepart ,@Start, @End) = abs(datediff (@datepart,Date ,@Start)) + abs(datediff (@datepart, Date,@End)))

 例句:

SELECT 1 WHERE datediff(@datepart ,@Start, @End) = abs(datediff (@datepart,Date ,@Start)) + abs(datediff (@datepart, Date,@End)))

算法原理:

起始时间到结束时间的长度=起始时间到某一时间点的长度+某一点的时间点到结束时间的长度。
例如:
输入值:{13,16}
比较值:{12,13,15,16,17}
16-13 = 3
1.
abs(12-13)=1 , abs(12-16)=4
1+4=5 !=3
2.
abs(13-13)=0, abs(13-16)=3
0+3=3 ==3
3.
abs(15-13)=2, abs(15-16)=1
2+1=3 ==3
4.
abs(16-13)=3, abs(16-16)=0
3+0=3 ==3
5
abs(17-13)=4,abs(17-16)=1
4+1=5 !=3

抱歉!评论已关闭.