在SQL SERVER中如果需要查询出当天、当月和当年的数据,可以通过DATEDIFF函数计算相差时间以获取正确的过滤条件。主要思路是通过DATEDIFF函数计算当前日期与数据日期的天数差、月份差和年数差,如果相差值为0,则表示为当前时间的数据,大于0或小于0则表示数据的时间比当前时间更加早或晚。
函数语法:DATEDIFF ( datepart , startdate , enddate )。参数datepart表示日期计算单位,常用有d,m,yyyy这3个值(d-天数,m-月份,yyyy-年份)。参数startdate表示计算的开始日期,简单点说是被减数,参数enddate表示结束日期,计算方式是enddate 中减去 startdate,值的单位取决于传入的datepart参数。
假设当前数据库中有张Article表,表中包含日期字段InputDate,获取当月数据的SQL语句如下:
SELECT COUNT(*) FROM [Article] WHERE DATEDIFF(m,[InputDate],GETDATE())=0
如果要获取当天和当年的数据,只要修改函数对应的datepart参数即可。
这里可以通过这些小范例举一反三,更加理解此函数的用法:
--计算当前日期与2015-12-21相差几天
PRINT DATEDIFF(d,'2015-12-21',GETDATE())
--计算当前日期与2015-12相差几月
PRINT DATEDIFF(m,'2015-11-02',GETDATE())
--计算当前日期与2015年相差几年
PRINT DATEDIFF(yyyy,'2015-06-07',GETDATE())
查看官方文档以获取更加详细的说明,部分文档截图如下:
详细参数说明:
原创文章,作者:kepupublish,如若转载,请注明出处:https://blog.ytso.com/98727.html