java 添加 date时间到数据库 ,时间不一致

在项目中存在数据库显示的时间和date的时间项目8个小时,这是由于mysql上的时区的问题,可以从两个解决的问题:

方案一: 设置数据库连接时区

在SpringBoot 的配置文件中的 spring.datecource.url 添加后缀  serverTimezone = Asia/shanghai 。设置本时区。

 

方案二: 设置mysql 时区

   查看mysql 时区 :

show variables like "%time_zone%";

 

 

这里分成修改当前会话和全局会话

  •   修改当前会话只对当前会话有效,退出会话就会失效
  •   修改全局会话是要退出当前会话后才有效

修改当前会话:

  

SET time_zone = "+8:00";

修改全局会话:

SET global time_zone = "+8:00";

这里最好修改全局会话

 

java  获取 date 时间 和全段展示不一致

 

后端时间和数据库相差8个小时

 

原因 :

  SpringBoot 中的@RestController 注解接口返回JSON格式数据,对于date类型,会被SpringBoot 默认的Jackson框架转化,而Jackson框架默认的时区是GMT(相对于中国少8个小时)。

 

解决方案:

  在application.yam 添加配置:

  

spring:
  jackson:
    time-zone: GMT+8

 

posted @ 2021-12-10 18:15  谢世林  阅读(838)  评论(0)    收藏  举报