mysql中的date类型直接比较大小是按照字符串比较还是时间戳
天蓬老师
天蓬老师 2017-04-17 11:49:15
0
1
591

mysql中的时间比如date类型的字段如果比较大小的话是按照字符串比较还是按照时间戳比较呢?

天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

全部回覆(1)
巴扎黑

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"。

Mysql關於Date類型的文件
http://dev.mysql.com/doc/refman/5.5/en/datetime.html
其中有這樣一段話: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.

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!