例如,下面的查询运行良好:
SELECT *
FROM quotes
WHERE expires_at <= '2010-10-15 10:00:00';
但这显然是在执行“字符串”比较--我想知道MySQL中是否有专门执行“日期时间”比较的函数。
发布于 2010-10-21 23:57:23
...this显然正在执行“字符串”比较
否-如果日期/时间格式与支持的格式匹配,则MySQL将执行隐式转换,以根据要比较的列将值转换为日期时间。同样的事情也会发生在:
WHERE int_column = '1'
...where将字符串值"1“转换为INTeger,因为int_column
的数据类型是INT,而不是CHAR/VARCHAR/TEXT。
如果您想显式地将字符串转换为日期时间,则STR_TO_DATE function将是最佳选择:
WHERE expires_at <= STR_TO_DATE('2010-10-15 10:00:00', '%Y-%m-%d %H:%i:%s')
发布于 2010-10-21 23:57:19
,但这显然是在执行'string‘比较
不是的。该字符串将自动转换为日期时间值。
请参阅11.2. Type Conversion in Expression Evaluation.
当运算符与不同类型的操作数一起使用时,会进行类型转换以使操作数兼容。有些转换是隐式发生的。例如,根据需要,MySQL会自动将数字转换为字符串,反之亦然。
发布于 2016-08-10 16:13:54
我知道它很老,但我只是遇到了这个问题,下面是我在SQL文档中看到的内容:
在使用BETWEEN和date或time值时,为获得最佳结果,请使用CAST()将这些值显式转换为所需的数据类型。示例:如果将日期时间与两个日期值进行比较,请将日期值转换为日期时间值。如果在与日期的比较中使用诸如'2001-1-1‘之类的字符串常量,请将字符串转换为日期。
我认为使用STR_TO_DATE更好,因为他们花了时间制作了一个函数,而且我在文档之间找到了这个……
https://stackoverflow.com/questions/3989385
复制相似问题