MySQL 的 DATE() 函数用于从 DATETIME 或 TIMESTAMP 中提取年 - 月 - 日日期部分,常用于条件筛选、分组;但直接使用 DATE(字段)= 日期可能导致索引失效,建议改用 >= 和
MySQL 中没有
DATE()函数用于“查询日期”,但有一个非常常用的 DATE() 函数,作用是 ** 从日期时间(DATETIME 或 TIMESTAMP)中提取日期部分(年 - 月 - 日)**,常用于日期条件筛选、分组或格式化。正确理解它的用途和搭配方式,才能高效做日期查询。DATE() 函数的作用与基本用法
DATE() 是一个提取函数,不是查询函数。它把类似
'2024-05-20 14:30:45'这样的完整时间值,转成纯日期'2024-05-20'。常见写法:
SELECT DATE('2024-05-20 14:30:45'); → '2024-05-20'SELECT DATE(NOW()); → 当前日期(如 '2024-05-20')SELECT DATE(create_time) FROM orders;→ 提取每条订单的创建日期用 DATE() 做精确日期范围查询
当字段是
DATETIME类型(比如create_time),直接用= '2024-05-20'会查不到数据,因为时间部分不匹配。这时用DATE()提取日期再比较,更直观:
SELECT * FROM orders WHERE DATE(create_time) = '2024-05-20';SELECT * FROM logs WHERE DATE(event_time) BETWEEN '2024-05-01' AND '2024-05-15';⚠️ 注意:这种写法在 大数据 量时可能无法使用索引(全表扫描),性能较差。生产环境推荐用范围查询替代:
WHERE create_time >= '2024-05-20' AND create_time- 等价于查当天所有记录,且能走
create_time索引配合 GROUP BY 按天统计
想看每天的订单数、访问量等,
DATE()是最自然的选择:
SELECT DATE(create_time) AS day, COUNT(*) AS cnt FROM orders GROUP BY DATE(create_time) ORDER BY day;- 结果示例:
2024-05-18 | 124、2024-05-19 | 156也可用别名简化:
GROUP BY day(前提是 SELECT 中用了AS day)。其他常用日期相关函数补充
DATE()常和这些函数搭配使用:
YEAR(), MONTH(), DAY():分别提取年、月、日数值DATE_ADD(), DATE_SUB():加减日期,如DATE_SUB(NOW(), INTERVAL 7 DAY)CURDATE():返回当前日期(不带时间),等价于DATE(NOW())STR_TO_DATE():把字符串转为日期,如STR_TO_DATE('20/05/2024', '%d/%m/%Y')
