如何在mysql中进行日期查询_date函数使用

MySQL 的 DATE() 函数用于从 DATETIME 或 TIMESTAMP 中提取年-月-日日期部分,常用于条件筛选、分组;但直接使用 DATE(字段)=日期可能导致索引失效,建议改用 >= 和

MySQL 中没有 DATE() 函数用于“查询日期”,但有一个非常常用的 DATE() 函数,作用是**从日期时间(DATETIME 或 TIMESTAMP)中提取日期部分(年-月-日)**,常用于日期条件筛选、分组或格式化。正确理解它的用途和搭配方式,才能高效做日期查询。

DATE() 函数的作用与基本用法

DATE() 是一个提取函数,不是查询函数。它把类似 '2025-05-20 14:30:45' 这样的完整时间值,转成纯日期 '2025-05-20'

常见写法:

  • SELECT DATE('2025-05-20 14:30:45'); → '2025-05-20'
  • SELECT DATE(NOW()); → 当前日期(如 '2025-05-20')
  • SELECT DATE(create_time) FROM orders; → 提取每条订单的创建日期

用 DATE() 做精确日期范围查询

当字段是 DATETIME 类型(比如 create_time),直接用 = '2025-05-20' 会查不到数据,因为时间部分不匹配。这时用 DATE() 提取日期再比较,更直观:

  • SELECT * FROM orders WHERE DATE(create_time) = '2025-05-20';
  • SELECT * FROM logs WHERE DATE(event_time) BETWEEN '2025-05-01' AND '2025-05-15';

⚠️ 注意:这种写法在大数据量时可能无法使用索引(全表扫描),性能较差。生产环境推荐用范围查询替代:

  • WHERE create_time >= '2025-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;
  • 结果示例:2025-05-18 | 1242025-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/2025', '%d/%m/%Y')