在 MySQL 中,DATE 函数主要用于提取日期部分或进行日期处理。它可以帮助你从日期时间类型的数据中获取纯日期,或者将字符串转换为日期格式。下面介绍几种常见的使用方式。
提取日期部分
当你有一个包含时间的
DATETIME或
TIMESTAMP字段时,可以使用
DATE()函数只获取日期部分。 例如:
SELECT DATE('2025-04-05 14:30:25'); -- 返回 '2025-04-05'如果表中有订单记录,包含下单时间:
SELECT order_id, DATE(order_time) AS order_date FROM orders;
这会返回每条订单的日期,忽略具体时间。
日期比较与筛选
使用
DATE()可以方便地按日期筛选数据,而不受时间影响。 比如查询某一天的所有记录:
SELECT * FROM logs WHERE DATE(log_time) = '2025-04-05';
这样即使
log_time包含时分秒,也能匹配当天所有条目。
字符串转日期
DATE()通常不用于直接转换字符串,但结合
STR_TO_DATE()或隐式转换可实现格式化输入。 注意:
如果字符串符合标准日期格式,MySQL 会自动转换:
SELECT DATE('2025-03-20'); -- 正确非标准格式可能需要先处理:
SELECT STR_TO_DATE('03/20/2025', '%m/%d/%Y');常见注意事项
使用
DATE()时需留意以下几点: 输入值必须是有效的日期或日期时间格式,否则返回
NULL对字段使用函数(如
DATE(column))可能导致索引失效,影响性能 建议在 WHERE 条件中尽量避免对列使用函数,可用范围查询代替 优化示例:
-- 不推荐 SELECT * FROM events WHERE DATE(event_time) = '2025-04-05'; <p>-- 推荐(可利用索引) SELECT * FROM events WHERE event_time >= '2025-04-05' AND event_time < '2025-04-06';
基本上就这些。DATE 函数简单实用,关键是在查询设计时注意性能影响。
