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')










