一、字符串与日期类型比较
Mysql在比较两种不同数据类型时,第一步是将他们转化为同一种类型,然后在比较。
官方文档
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”。
Mysql关于Date类型的文档
其中有这样一段话:
invalid dates such as '2004-04-31' are converted to '0000-00-00' and a warning is generated. With strict mode enabled, invalid dates generate an error.