MySQL中的DATE函数主要用于处理日期和时间值。以下是一些常见的DATE函数用法:
- NOW():返回当前的日期和时间。
SELECT NOW();
- CURDATE() 和 CURTIME():分别返回当前的日期和时间(没有时间部分)。
SELECT CURDATE(), CURTIME();
- DATE_ADD(date, INTERVAL expr unit):在给定的日期上添加指定的时间间隔。
SELECT DATE_ADD(NOW(), INTERVAL 1 DAY); -- 在当前日期上加一天
- DATE_SUB(date, INTERVAL expr unit):从给定的日期中减去指定的时间间隔。
SELECT DATE_SUB(NOW(), INTERVAL 1 MONTH); -- 从当前日期中减一个月
- DATEDIFF(date1, date2):计算两个日期之间的天数差。
SELECT DATEDIFF('2023-10-01', '2023-09-30'); -- 计算两个日期之间的天数差
- DATE_FORMAT(date, format):按照指定的格式格式化日期。
SELECT DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%s'); -- 以'YYYY-MM-DD HH:MM:SS'的格式显示当前日期和时间
- DAY(date)、MONTH(date) 和 YEAR(date):分别返回给定日期的日、月和年部分。
SELECT DAY('2023-10-05'), MONTH('2023-10-05'), YEAR('2023-10-05'); -- 分别返回5、10和2023
- WEEK(date):返回给定日期是一年中的第几周。
SELECT WEEK('2023-10-05'); -- 返回40(根据MySQL的周算法,第一周是包含周四的周)
- LAST_DAY(date):返回给定日期是该月的最后一天。
SELECT LAST_DAY('2023-10-05'); -- 返回'2023-10-31'
- STR_TO_DATE(str, format):将一个字符串转换为日期,根据指定的格式。
SELECT STR_TO_DATE('05-10-2023', '%d-%m-%Y'); -- 返回'2023-10-05'
这些函数在处理日期和时间数据时非常有用,可以帮助你执行各种日期和时间相关的操作。