当前位置: 首页 > MySQL数据库

MySQL学习之日期函数怎么使用

时间:2026-01-27 10:38:00
获取 系统时间 函数

“NOW()” 函数 能够获得当前系统日期和时间,格式如下:“YYYY-MM-DD hh:mm:ss” (这里的小时单位是 24 小时制)

“CURDATE()” 函数 能够获取到当前系统的日期,格式如下:“YYYY-MM-DD”

“CURTIME()” 函数 能够获得当前系统时间,格式如下:“hh:mm:ss” (24小时制)

SELECTNOW();--返回结果"2020-06-1017:22:51"(示例)
SELECTCURDATE();--返回结果"2020-06-10"
SELECTCURTIME();--返回结果"17:22:52"
日期格式化 函数

“DATE_FORMAT()” 函数 用于格式化日期,可以帮助我们提取出非常有用的日期信息

语法如下:

DATE_FORMAT(日期, 表达式)

SELECTename,DATE_FORMAT(hiredate,"%Y")AS"入职日期"FROMt_emp;
占位符作用占位符作用
%Y年份%m月份
%d日期%w星期(数字)- (0为周日)
%W星期(名称)- (英文)%j本年的第几天
%U本年的第几周%H小时(24)
%h小时(12)%i分钟
%s%r时间(24)
%T时间(12)

日期函数练习

利用 “日期函数” ,查询生日那天是周几。

SELECTDATE_FORMAT("2018-01-01","%W");--返回结果为"Monday"
日期函数练习

利用 “日期函数” ,查询 1981 年上半年入职的员工人数有多少人?

SELECTCOUNT(*)FROMt_empWHEREDATE_FORMAT(hiredate,"%Y")=1981ANDDATE_FORMAT(hiredate,"%m")<=6;
日期计算的注意事项

在 MySQL 中,两个日期之间是不能够直接进行相加或相减的;同时,日期也是不能够与数字进行相加、减的。

原因在于,日期是一个特殊计算单位,而且进制之间也不是普通的十进制那样。

虽然我们使用 日期 去进行 “+1” 的操作不会产生语法上的错误,但是得到的结果是纯数字,而不是我们想要的日期格式的结果。(示例如下)

SELECTename,hiredate,hiredate+1FROMt_emp;
日期偏移计算

DATE_ADD() 函数 可以实现日期的偏移计算,并且在 时间单位的处理上,比较的灵活。

语法如下:

SELECTDATE_ADD("原始日期",INTERVAL,偏移量,时间单位)--INTERVAL是关键字

"DATE_ADD() 函数" 演示案例如下

SELECTDATE_ADD(NOW(),INTERVAL10DAY);--得到的结果为10天之后的日期时间
SELECTDATE_ADD(NOW(),INTERVAL-500MINUTE);--得到的结果为500分钟之前的日期时间
SELECTDATE_ADD(DATE_ADD(NOW(),INTERVAL-6MONTH),INTERVAL-3DAY);--得到的结果为6个月3天之前的日期时间
SELECTDATE_FORMAT(DATE_ADD(DATE_ADD(NOW(),INTERVAL-6MONTH),INTERVAL-3DAY),"%Y-%m-%d")ASDATE;--返回"%Y-%m-%d"格式结果
计算日期之间相隔的天数

DATEDIFF() 函数 用来计算两个日期之间相差的天数,语法如下:

DATEDIFF("日期", "日期")

查询 10 部门中年收入超过 15000 且工龄超过 20年 的员工的信息。

SELECTempno,ename,sal,hiredateFROMt_empWHEREdeptno=10AND(sal+IFNULL(comm,0))*12>=15000ANDDATEDIFF(NOW(),hiredate)/365>=20--IFNULL(expr1,expr2):IFNULL函数的语法,当第一个参数的值为null的时候,则返回第二个参数的值--DATEDIFF(expr1,expr2):DATEDIFF函数的语法,计算第一个日期与第二个日期的偏差时间差--NOW():NOW函数可以获得当前日期

上一篇:MySQL之InnoDB中锁的情况分析
下一篇:MySQL流程控制之while、repeat、loop循环实例分析
mysql
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器
  • 英特尔第五代 Xeon CPU 来了:详细信息和行业反应
  • 由于云计算放缓引发扩张担忧,甲骨文股价暴跌
  • Web开发状况报告详细介绍可组合架构的优点
  • 如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳
  • 美光在数据中心需求增长后给出了强有力的预测
  • 2027服务器市场价值将接近1960亿美元
  • 生成式人工智能的下一步是什么?
  • 分享在外部存储上安装Ubuntu的5种方法技巧
  • 全球数据中心发展的关键考虑因素
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器

    英特尔第五代 Xeon CPU 来了:详细信息和行业反应

    由于云计算放缓引发扩张担忧,甲骨文股价暴跌

    Web开发状况报告详细介绍可组合架构的优点

    如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳

    美光在数据中心需求增长后给出了强有力的预测

    2027服务器市场价值将接近1960亿美元

    生成式人工智能的下一步是什么?

    分享在外部存储上安装Ubuntu的5种方法技巧

    全球数据中心发展的关键考虑因素