mysql中的date类型直接比较大小是按照字符串比较还是时间戳

如题所述

Mysql在比较两种不同数据类型时,第一步是将他们转化为同一种类型,然后在比较。那么Date和String在比较的时候,一定是把String转化为Date吗?答案是Yes.
http://dev.mysql.com/doc/refman/5.0/en/type-conversion.html
If one of the arguments is a TIMESTAMP or DATETIME column and the other argument is a constant, the constant is converted to a timestamp before the comparison is performed.
简单举个例子,如果是用字符串比较,"2004-04-31"这个string应该比2004-01-01这个date来得大,但是4-31是一个invalid的日期(4月是小月),会被转化成"0000-00-00",所以2004-01-01 (日期) > "2014-04-31"。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2019-05-17
Mysql在比较两种不同数据类型时,第一步是将他们转化为同一种类型,然后在比较。
那么Date和String在比较的时候,一定是把String转化为Date吗?
答案是Yes.
第2个回答  2017-08-30
mysql中的date类型直接比较大小是按照字符串比较还是时间戳

按照时间戳比较大小