SQL SERVER中查询当天、当月、当年数据的SQL语句

来源:互联网 发布:js改变css display 编辑:程序博客网 时间:2024/06/11 06:52

在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())

查看官方文档以获取更加详细的说明,部分文档截图如下:

使用DATEDIFF函数计算当天当月当年

详细参数说明:

datepart参数说明截图

startdate和enddate参数说明截图

原创粉丝点击