首页 >数据库 >mysql教程 >如何从 MySQL 的 DateTime 列中高效提取日期?

如何从 MySQL 的 DateTime 列中高效提取日期?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-02 17:33:10771浏览

How to Efficiently Extract Dates from DateTime Columns in MySQL?

从日期时间列中高效选择日期

使用日期时间数据类型时,通常需要提取特定组件,例如日期或时间。本文解决了从 MySQL 中的日期时间列检索日期的挑战。

问题

常见查询是根据特定日期过滤行,如下例所示:

SELECT * FROM data
WHERE datetime = '2009-10-20'
ORDER BY datetime DESC;

但是,提供的解决方案使用 BETWEEN 子句定义日期范围 '2009-10-20 00:00:00' 到 '2009-10-20 23:59:59' 返回一个空结果集。

解决方案

为了有效提取日期,MySQL 提供了 DATE()函数,它返回日期时间值的日期部分。在 WHERE 子句中使用 DATE() 允许与日期文字直接比较:

SELECT * FROM data
WHERE DATE(datetime) = '2009-10-20'
ORDER BY datetime DESC;

有时可以提高性能的替代方法是使用带有通配符后缀的 LIKE 运算符:

SELECT * FROM data
WHERE datetime LIKE '2009-10-20%'

但是,值得注意的是,LIKE 比较可能会对性能产生影响,正如其他 Stack Exchange 线程中所讨论的那样。

以上是如何从 MySQL 的 DateTime 列中高效提取日期?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn