大家好,我是宁一。
今天是我们的第21课:SQL中的日期函数。
MySQL中内置的日期函数,包括获取日期、日期格式化、日期计算,我们分别来看看。
1、获取日期函数
MySQL内置的获取日期时间函数:
- SELECT
- NOW() AS '当前日期+时间',
- CURDATE() AS '当前日期',
- CURTIME() AS '当前时间';

获取具体年月日函数:
- SELECT
- YEAR("2022-04-11 15:44:28") AS '年',
- MONTH("2022-04-11 15:44:28") AS '月',
- DAY("2022-04-11 15:44:28") AS '日',
- HOUR("2022-04-11 15:44:28") AS '小时',
- MINUTE("2022-04-11 15:44:28") AS '分钟',
- SECOND("2022-04-11 15:44:28") AS '秒',
- DAYNAME("2022-04-11 15:44:28") AS '星期几',
- MONTHNAME("2022-04-11 15:44:28") AS '几月';

实例:在Students表中,找出生日Sage为1995年的学生记录。

- SELECT *
- FROM Students
- WHERE YEAR(Sage) = 1995

我们之前也做过这个题,用BETWEEN…AND…实现的,可以点击主页找到第五讲--WHERE条件子句复习一下~
我们主要使用 DATE_FORMAT、TIME_FORMAT函数对日期和时间进行格式化,来看看具体用法。
- SELECT
- NOW() AS "现在时间",
- DATE_FORMAT(NOW(), '%Y.%m.%d') AS '格式化日期',
- TIME_FORMAT(NOW(), '%h:%i:%s') AS '格式化时间'

可以使用的格式有:

实际业务中,我们经常要计算日期和时间,比如在日期基础上增加减少一天,或者计算日期间隔,来看看具体用法。
在日期基础上增加减少天数:
- SELECT
- NOW() AS "现在时间",
- DATE_ADD(NOW(), INTERVAL 1 DAY) AS "增加1天",
- DATE_SUB(NOW(), INTERVAL 1 DAY) AS "减少1天"

还可以增加减少年、月、小时、分钟:
- SELECT
- NOW() AS "现在时间",
- DATE_ADD(NOW(), INTERVAL 1 YEAR) AS "增加1年",
- DATE_SUB(NOW(), INTERVAL 1 MONTH) AS "减少1天",
- DATE_SUB(NOW(), INTERVAL 1 HOUR) AS "减少1小时"

计算两个日期间隔天数:
- SELECT
- DATEDIFF('2022-04-11','2021-04-11') AS "间隔天数",
- DATEDIFF('2022-04-11 01:00','2022-04-10 23:00') AS "间隔天数"

注意DATEDIFF函数会忽略时间部分,只算日期差异,比如,上面SQL语句中04-10 23:00到04-11 01:00只差了两个小时,但是用DATEDIFF函数会计算时间间隔为1天。
作业:在Students表中,通过学生生日Sage,计算每个学生的年龄,最终显示今天日期、学生姓名、学生年龄3列。
作业解析:通过DATEDIFF函数,计算今天与学生生日Sage相差的天数,除以365得到年数,再通过FLOOR数值函数,取小于年龄的大整数。
- SELECT
- DATE_FORMAT(NOW(),'%Y-%m-%d') AS '今天日期',
- Sname AS '学生姓名',
- FLOOR(DATEDIFF(NOW(),Sage)/365) AS "学生年龄"
- FROM Students;

要注意上面这些函数不是标准SQL语句,而是MySQL软件中内置的函数,在Oracle、或者SQL Server中不一定通用。
下节课我们讲讲 IF 函数。
点击关注,更新课程第一时间通知哦~