我是靠谱客的博主 个性仙人掌,最近开发中收集的这篇文章主要介绍mysql中的date类型直接比较大小是按照字符串比较还是时间戳,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

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

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.


最后

以上就是个性仙人掌为你收集整理的mysql中的date类型直接比较大小是按照字符串比较还是时间戳的全部内容,希望文章能够帮你解决mysql中的date类型直接比较大小是按照字符串比较还是时间戳所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(58)

评论列表共有 0 条评论

立即
投稿
返回
顶部