前言

在开发中,我们进行数据库查询日期类型的时候,往往不是我们想要的时间格式,比如下面的情况:


我数据库里面把这些日期相关的字段都设置为datatime格式了:


image.png

数据类型如下:

image.png



实体是这么配置的:

image.png



那么默认查询出来的结果就是这样的:

image.png



救命啊,这什么格式啊,完全不是我想要的年月日时分秒。


其实想解决这种问题也很简单,无非就是时间格式不对吗,下面通过全局设置和局部设置两个方面解决这种问题


解决问题

1 全局设置(推荐)

一般来说,为了方便和统一,我们可以设置全局处理日期格式化,在配置文件中进行配置


想到application配置文件有properties和yaml两种格式,我分别给大家准备好了不同格式需要的代码。


properties格式

# 设置全局的日期格式为年月日时分秒

spring.jackson.date-format=yyyy-MM-dd HH:mm:ss

# 世界标准时间,为了方式时差,需要+8小时

spring.jackson.time-zone=GMT+8

 image.png



yaml格式

当然,上面是properties格式,如果你用的是yaml格式,那么就可以使用下面的配置:


spring 

  jackson: 

    date-format: yyyy-MM-dd HH:mm:ss #设置全局的日期格式为年月日时分秒

    time-zone: GMT+8 #世界标准时间,为了方式时差,需要+8小时

 

加上这个配置项之后就可以重启服务了,再次访问接口:


可以发现是我们想要的时间格式了,但是查出来的时间比数据库多了8小时


这就是加上时区引起的,如果加上时区配置项,就是会在原有的时间上+8小时,所以说这个时区配置项看个人需求,可以配置也可以不配置

image.png



2 局部设置(不推荐)

虽然全局配置很香,但是有的时候我们不能强制的让全局保持统一格式,只对个别的进行时间处理


那这个时候,局部设置的作用就体现出来了,为了方便演示,我把全局设置给注释掉:

image.png



引入pom

局部设置需要使用fastjson依赖,所以需要下下载依赖


 <!–fastjson–>

        <dependency>

            <groupId>com.alibaba</groupId>

            <artifactId>fastjson</artifactId>

            <version>1.2.58</version>

        </dependency>

 

加入注解

在需要进行时间格式化的字段上加入注解:


 @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")

 

它有两个参数:


1:pattern:时间格式

2:timezone:时区


原理和全局设置的两个参数是一样的


这里我估计拿出一个加了注解,一个没加注解的时间属性进行比较:

image.png



重启项目,测试接口,对比两个日期格式


image.png


当然,和全局配置一样,注解里面的参数也是根据自己的需求灵活选择的:


比如我这里不想要时区了,并且想要年月日的格式,那就直接改:

image.png



结果当然是你怎么配置就是什么样的啦:

image.png



总结

以上就是在SpringBoot项目设置全局和局部时间格式化的两种方式了,大家根据自己的需求灵活选择即可。



————————————————

版权声明:本文为CSDN博主「小花皮猪」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/weixin_46713508/article/details/128555546