首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >mysql日期时间比较

mysql日期时间比较
EN

Stack Overflow用户
提问于 2010-10-21 23:54:45
回答 3查看 110.6K关注 0票数 64

例如,下面的查询运行良好:

代码语言:javascript
复制
SELECT * 
  FROM quotes 
 WHERE expires_at <= '2010-10-15 10:00:00';

但这显然是在执行“字符串”比较--我想知道MySQL中是否有专门执行“日期时间”比较的函数。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2010-10-21 23:57:23

...this显然正在执行“字符串”比较

否-如果日期/时间格式与支持的格式匹配,则MySQL将执行隐式转换,以根据要比较的列将值转换为日期时间。同样的事情也会发生在:

代码语言:javascript
复制
WHERE int_column = '1'

...where将字符串值"1“转换为INTeger,因为int_column的数据类型是INT,而不是CHAR/VARCHAR/TEXT。

如果您想显式地将字符串转换为日期时间,则STR_TO_DATE function将是最佳选择:

代码语言:javascript
复制
WHERE expires_at <= STR_TO_DATE('2010-10-15 10:00:00', '%Y-%m-%d %H:%i:%s')
票数 119
EN

Stack Overflow用户

发布于 2010-10-21 23:57:19

,但这显然是在执行'string‘比较

不是的。该字符串将自动转换为日期时间值。

请参阅11.2. Type Conversion in Expression Evaluation.

当运算符与不同类型的操作数一起使用时,会进行类型转换以使操作数兼容。有些转换是隐式发生的。例如,根据需要,MySQL会自动将数字转换为字符串,反之亦然。

票数 21
EN

Stack Overflow用户

发布于 2016-08-10 16:13:54

我知道它很老,但我只是遇到了这个问题,下面是我在SQL文档中看到的内容:

在使用BETWEEN和date或time值时,为获得最佳结果,请使用CAST()将这些值显式转换为所需的数据类型。示例:如果将日期时间与两个日期值进行比较,请将日期值转换为日期时间值。如果在与日期的比较中使用诸如'2001-1-1‘之类的字符串常量,请将字符串转换为日期。

我认为使用STR_TO_DATE更好,因为他们花了时间制作了一个函数,而且我在文档之间找到了这个……

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3989385

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档