DATE函数用于提取日期部分或处理日期,如从DATETIME中获取日期、筛选指定日期的数据,需注意避免在WHERE条件中对列使用函数以防索引失效。

在 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 包含时分秒,也能匹配当天所有条目。
动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包
字符串转日期
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';-- 推荐(可利用索引) SELECT * FROM events WHERE event_time >= '2025-04-05' AND event_time < '2025-04-06';
基本上就这些。DATE 函数简单实用,关键是在查询设计时注意性能影响。









