MySQL中Date,DateTime,TimeStamp和Time的解释和区别
admin
2024-03-29 17:47:36

以下场景应用及后台取值 用到com.alibaba.fastjson.annotation(fastjson 阿里巴巴开源框架)以及springBoot注解

Date

名称解释
显示格式YYYY-MM-DD
显示范围1901-01-01 到 9999-01-01
应用场景当业务需求中只需要精确到天时,可以用这个时间格式
后台取值@JSONField(format=“yyyy-MM-dd”)


DateTime

名称解释
显示格式YYYY-MM-DD HH:mm:ss
显示范围1601-01-01 00:00:00 到 9999-12-31 23:59:59
应用场景当业务需求中需要精确到秒时,可以用这个时间格式
后台取值@JSONField(format=“yyyy-MM-dd HH:mm:ss”)


TimeStamp

名称解释
显示格式YYYY-MM-DD HH:mm:ss
显示范围1601-01-01 00:00:00 到 9999-12-31 23:59:59
应用场景当业务需求中需要精确到秒或者毫秒时,或者该系统用于不同时区,可以用这个时间格式
 
后台取值@JSONField(format=“yyyy-MM-dd HH:mm:ss:SSS”)(这里只会精确到秒)


Time

名称解释
显示格式HH:mm:ss
显示范围00:00:00 到 23:59:59
应用场景当业务需求中只需要每天的时间,可以用这个时间格式
后台取值@JSONField(format=“HH:mm”)(这里是只精确到分,数据库存的也就是只精确到分,比如 09:36:00,如果需要精确到秒。需要使用@JSONField(format=“HH:mm:ss”))


Date,DateTime,TimeStamp和Time 比较

从 显示格式、显示范围、应用场景 和 后台取值的去进行比较


DateTime和TimeStamp都是年月日时分秒,为什么还有这两个类型呢?

  1. 精度:DateTime和TimeStamp都可以精确到毫秒(我目前使用的5.5的mysql,所以只能精确到秒,据说高版本的可以用TIMESTAMP(3)与 DATETIME(3)精确到毫秒。),但是用的很少,一般精确到毫秒都是用Timestamp,另外关于Timestamp的10位和13位的区别请参考我的另一篇文章java时间戳 10位和13位分别是怎么来的?
  2. DateTime和TimeStamp最大的区别只是用的场景不同,如果你的应用 是用于不同时区(就是国内和国外同时使用),这时候如果用dateTime就会出现各种各样的问题,但是如果使用TimeStamp就不会出现这种时差的问题。
  3. 误区:之前我也也为datetime和TimeStamp是一样的,因为他们在数据库存的时间都是YYYY-MM-DD HH:mm:ss格式的,但是TimeStamp类型存的是10位或者13位的时间戳,不要被表现骗了,使用如下的SQL即可获取时间戳里面具体存的什么
    select UNIX_TIMESTAMP(TIME) date from table

相关内容

热门资讯

延安旅游攻略:一家老小5口人,... 每到暑假或国庆长假,总有很多家庭游客向我们咨询:“我们一家老小来延安,有老人有孩子,行程该怎么安排才...
原创 韩... 韩国明星到延吉旅游,第一次挑战吃羊鞭,惊得嘴都合不上了! 全昭旻等人在延吉录制节目,刚到延吉,他们...
国庆黄金周景区情况:大同古城半... 文| 芙昕 编辑 | 芙昕 国庆长假,很多人都计划着出门走走,可一到了那些热门景点,看到的往往不是山...
来大东北一共分两步:先“冷藏”... 还在被“东北=冰窖”的刻板印象吓退? 南方的“小土豆”们 别急着裹紧小棉袄 这个冬天 让“气候缓冲带...
第三届“长城之约”活动在河北涞... 11月15日,第三届"长城之约"全球推广活动暨世界文化遗产对话15日在河北省保定市涞源县启幕。 本次...