在项目中存在数据库显示的时间和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