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

11次阅读

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

如何在 mysql 中进行日期查询_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 | 1242024-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')
星耀云
版权声明:本站原创文章,由 星耀云 2026-01-03发表,共计1203字。
转载说明:转载本网站任何内容,请按照转载方式正确书写本站原文地址。本站提供的一切软件、教程和内容信息仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。
text=ZqhQzanResources