/*十有三博客*/
  • 首页
  • 关于本站
  • 网站地图
  • 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使用ROW_NUMBER函数获取没有ID的当前数据的上下文数据(上一条和下一条)
  • 解决COMMIT TRANSACTION 请求没有对应的 BEGIN TRANSACTION错误
  • SQL 获取上一条数据
  • MongoDB学习笔记:28663 Cannot start server. The default storage engine 'wiredTiger' is not available
  • 解决SQL Service创建链接服务器出现(null) 是无效的产品名称的问题
  • 解决MongoVUE 修改错误: cannot use 'j' option when a host does not have journaling enabled

文章分类

.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重构重命名的快捷键

推荐文章

  • 使用国内镜像解决Git for Windows下载缓慢及不稳定的问题
  • 解决OneNote安卓版同步到Windows版出现中文乱码
  • HTML使用相对路径获取各级目录下文件
  • Windows Server 2012 R2 更改计算机管理员账号提示“出现扩展错误,未能保存本地策略数据库”
  • 一次头疼的IIS故障经历:IIS 8.5的URL重写模块无法正常运行

友情链接

  • Passingwind的博客
  • 码友网

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