/*十有三博客*/
  • 首页
  • 关于本站
  • 网站地图
  • RSS订阅

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

2016-01-22 十有三 0 浏览:2万+ 数据库 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参数说明截图


作者:十有三

出处:https://shiyousan.com/post/635890574417651293

版权声明:本文采用知识共享许可协议:署名-相同方式共享 4.0 国际(CC BY-SA 4.0)。欢迎转载本文,转载请声明出处或保留此段声明。


  • 上一篇: TortoiseSVN以标准差异文件显示修改会出现中文乱码
  • 下一篇: MongoDB学习笔记:batchInsert is not a function

相关文章
  • 解决SQL SERVER 2014 不允许保存更改。您所做的更改要求删除并重新创建以下表。您对无法重新创建的表进行了更改或者启用了"阻止保存要求重新创建表的更改"选项
  • 创建 SQL Server Express自动备份数据库功能
  • MongoDB在Windows Server 2012 R2中的安全部署
  • 解决SQL SERVER还原数据库错误:备份介质集不完整。介质簇计数: 2。缺失的介质簇序列号: 1
  • SQL使用ROW_NUMBER函数获取没有ID的当前数据的上下文数据(上一条和下一条)
  • SQL Service 2008 SQL语句 四舍五入保留两位小数

文章分类

.NET技术 123 数据库 24 Web前端 21 网站建设运维 37 操作系统与应用 66 程序猿日常 11 开发工具 12 其他随笔 13

文章标签

ASP.NET ASP.NET MVC C# CSS HTML IIS Javascript Linux MongoDB MySql SQL SQL Server Visual Studio Windows系统 版本控制系统 插件工具 服务器 搞笑娱乐 好文分享 软件应用 生活知识 手机问题 随笔 网络知识 网站设计优化 网站维护 养生保健 异常处理 硬件设备 游戏攻略

热门文章

  • IIS8如何安装和使用URL重写工具-URL Rewrite
  • 林蛋大与楚中天,朱肚皮与朱月坡
  • 解决IE11安装升级失败和在安装前需要更新的问题
  • Windows Server 2012无法安装 .NET3.5-安装角色或功能失败,找不到源文件
  • VS重构重命名的快捷键

推荐文章

  • (恶搞)程序搞笑:程序员和科比搞笑对话
  • IIS上设置ARR导致所有网站无法正常打开
  • C# List.Join方法
  • 解决Windows Server 2012 R2 百度网盘无法打开提示丢失Wlanapi.dll
  • 解决安卓中Outlook联系人无法同步两个手机号码的问题-手机2无法同步

友情链接

  • Passingwind的博客
  • 码友网

知识共享许可协议 CC BY-SA 4.0本站作品采用知识共享许可协议:署名-相同方式共享 4.0 国际(CC BY-SA 4.0)。
闽ICP备15003702号
闽公网安备 35020302035102号