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

在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参数说明截图

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值