存储方式
timestamp:对于TIMESTAMP,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。
datetime:不做任何改变,基本上是原样输入和输出。
使用场景
timestamp 使用场景:计算飞机飞行时间
一架飞机,从中国北京起飞,降落在美国纽约,计算它从北京飞往纽约的飞行时间。飞机在北京时间 2021-10-10 11:05:00 从北京起飞,在纽约时间 2021-10-10 09:50:00 降落(JL8006)。
这个场景中,如果使用 timestamp 来存时间,起飞和降落时间的值,都会被转换成 UTC 时间,所以它们直接相减即可获得结果。但如果使用 datetime格式存时间,还需要进行转换,才可以完成,容易出错。
datetime使用场景:记录信息修改时间
如果只是记录文件修改时间,最后更新时间这种不涉及加减转换的情况,用 DATATIME 来存更直接,更方便,可读性高,不绕弯子,不容易出错。
↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑
原文链接:https://blog.csdn.net/djydjy3333/article/details/122377580
另外话题
时间字段在实体类中注解的区别
@JsonFormat
该注解来源于jackson
包中的注解,主要用来控制后端返回给前端
的日期格式,通常用在返回给前端的实体类中。
案例如下:
class User{
private Integer id;
@JsonFormat(pattern=”yyyy-MM-dd”,timezone=”GMT+8”)
private Date birthday;
}
注意:
如果直接使用 @JsonFormat(pattern=”yyyy-MM-dd”)就会出现2018-08-01 08:00:00的情况, 会相差8个小时,因为我们是东八区(北京时间)。所以我们在格式化的时候要指定时区(timezone )
@JsonField
该注解来源于阿里巴巴的fastjson,是阿里巴巴的开源框架,主要进行JSON解析和序列化。 @JsonField是集前端到后端、后端到前端数据传输于一身的注解
其中经常用到的参数有以下:
所以JsonField中的 format 属性功能可以代替JsonFormat了。
更多关于@JsonField的用法可以查看我的另一篇博客博客,这里就不再讲解
@DateTimeFormat
是spring自带的处理框架,主要用于将时间格式化。
在实体类上的注解使用,可以按格式处理前端传过来的日期
@DateTimeFormat(pattern=”yyyy-MM-dd”)
private Date date;
总结
@DateTimeFormat是前端数据到后端数据的处理
@JsonFormat是后端到前端数据的处理
@JsonField是集两者于一身的一个注解
综上所述,更建议使用@JsonField