我是靠谱客的博主 烂漫热狗,最近开发中收集的这篇文章主要介绍mysql datetime格式_Mybatis和Mysql的Datetime的一些问题,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

Mysql的时间类型

时间类型有time, date, datetime, timestamp

如Mysql官方文档所述:

time 没有date,date没有time,datetime是date和time的集合,

而timestamp也是如此。

MySQL retrieves and displays DATETIME values in ‘YYYY-MM-DD HH:MM:SS’ format. The supported range is ‘1000-01-01 00:00:00’ to ‘9999-12-31 23:59:59’.

Datetime范围大一些。

TIMESTAMP has a range of ‘1970-01-01 00:00:01’ UTC to ‘2038-01-19 03:14:07’ UTC.

范围小一些,所以不推荐使用TIMESTAMP,如果你确定你的代码不能用到2038年。

共同点

A DATETIME or TIMESTAMP value can include a trailing fractional seconds part in up to microseconds (6 digits) precision

后面支持带微秒。

the format for these values is ‘YYYY-MM-DD HH:MM:SS[.fraction]’, the range for DATETIME values is ‘1000-01-01 00:00:00.000000’ to ‘9999-12-31 23:59:59.999999’, and the range for TIMESTAMP values is ‘1970-01-01 00:00:01.000000’ to ‘2038-01-19 03:14:07.999999’.

区别

MySQL converts TIMESTAMP values from the current time zone to UTC for storage, and back from UTC to the current time zone for retrieval. (This does not occur for other types such as DATETIME.)

Mysql会自动把当前时区的时间以UTC时间存储,取出又会自动转成当地时区。而Datetime没有经历这些内容。

mybatis

好奇Mybatis在查询 ResultType=“HashMap”的时候,如何处理DateTime的类型。。

问题:Mybatis如何处理Mysql的Datetime类型

查了一下Mybatis源码:

TypeHandlerRegistry(){

...

this.register((Class)Date.class, (TypeHandler)(new DateTypeHandler()));

this.register((Class)Date.class, JdbcType.DATE, (TypeHandler)(new DateOnlyTypeHandler()));

this.register((Class)Date.class, JdbcType.TIME, (TypeHandler)(new TimeOnlyTypeHandler()));

this.register((JdbcType)JdbcType.TIMESTAMP, (TypeHandler)(new DateTypeHandler()));

this.register((JdbcType)JdbcType.DATE, (TypeHandler)(new DateOnlyTypeHandler()));

this.register((JdbcType)JdbcType.TIME, (TypeHandler)(new TimeOnlyTypeHandler()));

this.register((Class)java.sql.Date.class, (TypeHandler)(new SqlDateTypeHandler()));

this.register((Class)Time.class, (TypeHandler)(new SqlTimeTypeHandler()));

this.register((Class)Timestamp.class, (TypeHandler)(new SqlTimestampTypeHandler()));

...

}

所以说,DateTime应被SqlDateTypeHandler转换成java.util.Date才对。

然而并不是,我的程序返回了HashMap,其中DateTime类型的数据被处理成 java.sql.TimeStamp。

这不科学

于是想了想,Mybatis没必要这么处理,Object,他又不知道Object是什么类型,所以应该调用的是 ResultSet的getObject方法才对,因为这样简单粗暴,最终是要用Object存储的,不必转换。

去查了JDBC官方文档,这是符合事实的。疑惑顿时解开。

MySQL Type NameReturn value of GetColumnClassNameReturned as Java Class

DATETIME

DATETIME

java.sql.Timestamp

DATE

DATE

java.sql.Date

TIMESTAMP[(M)]

TIMESTAMP

java.sql.Timestamp

TIME

TIME

java.sql.Time

完。

三级标题怎么是这样。

????

最后

以上就是烂漫热狗为你收集整理的mysql datetime格式_Mybatis和Mysql的Datetime的一些问题的全部内容,希望文章能够帮你解决mysql datetime格式_Mybatis和Mysql的Datetime的一些问题所遇到的程序开发问题。

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

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

评论列表共有 0 条评论

立即
投稿
返回
顶部