mysql从数据库查询的时间与实际时间相差8小时(时区问题)

解决方法:

设置spring配置文件:

1、spring.datasource.url=jdbc:mysql://10.35.105.25:3306/database?characterEncoding=utf-8&serverTimezone=GMT%2B8

数据库配置后面加上&serverTimezone=GMT%2B8

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

     spring.jackson.time-zone=GMT+8

第一步为设置数据库时间为东八区(北京)时间,保证debug时候从数据库查出时间一致。第二步为返回给前端的时间格式和时区设定,保证前端页面显示时间和数据库一致。

 

下面是多8小时的例子。

举例说明:

数据库字段为time,数据类型设置为timeStamp,值为:2019-05-23 09:49:00

代码中:private Date time;

如果设置:spring.datasource.url=jdbc:mysql://10.35.105.25:3306/database?characterEncoding=utf-8&serverTimezone=UTC

数据库时间设置为UTC,代码中debug时,就会发现time时间查出来为Thu May 23 17:49:00 CST 2019,多8个小时。因为数据库时间是UTC世界统一时间,而代码中默认为北京时间(东八区),东八区要早8小时,也就是多8小时。时区差值可以百度了解。

前端页面显示:Thu May 23 17:49:00 CST 2019格式为Date默认格式,通常我们是yyyy-MM-dd HH:mm:ss格式。所以可以加配置:

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

 spring.jackson.time-zone=GMT+8

这样返回给前端就是正常格式了。

 

 

 

 

  • 17
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值