数据库时间和 java 时间不一致解决方案

java添加 date 到数据库,时间不一致
使用 date 添加到数据库,数据库显示的时候和date时间相差 8 个小时,这是由于 mysql 上的时区的问题,这里有两个解决方案:

方案一: 设置数据库连接时区
在 springboot 的配置文件中的 spring.datasource.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 类型的数据,会被 spring-boot 默认的Jackson框架转化,而 Jackson 框架默认时区是 GMT(相对于中国少了 8 个小时)。

解决方案
在 application.yml 添加配置:

spring:
  jackson:
    time-zone: GMT+8

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个解决方案的示例: 1. 在数据库中将所有时间都以UTC时间存储,可以使用数据库中的时间类型(如MySQL中的DATETIME类型)。 2. 在前端展示时,使用JavaScript中的Date对象将UTC时间转换为本地时间。例如: ``` // 假设数据库中存储的时间为2022-01-01 12:00:00 const utcTime = new Date('2022-01-01T12:00:00Z'); const localTime = new Date(utcTime.getTime() - utcTime.getTimezoneOffset() * 60000); console.log(localTime); // 输出本地时间 ``` 上述代码中,将UTC时间转换为JavaScript中的Date对象,并使用getTimezoneOffset()方法获取当前本地时区与UTC时区的时间差,并将其转换为毫秒数,最后使用getTime()方法获取时间戳,得到本地时间。 3. 如果需要在前端向后台提交时间,可以将本地时间转换为UTC时间。例如: ``` const localTime = new Date(); // 当前本地时间 const utcTime = new Date(localTime.getTime() + localTime.getTimezoneOffset() * 60000); console.log(utcTime.toISOString()); // 输出UTC时间 ``` 上述代码中,首先获取当前本地时间,然后使用getTimezoneOffset()方法获取当前本地时区与UTC时区的时间差,并将其转换为毫秒数,将其加上本地时间时间戳,得到UTC时间。最后使用toISOString()方法将UTC时间转换为ISO格式的字符串,以便提交到后台。 4. 如果需要在后台中进行时区转换,可以使用服务器端的时间库,例如Java中的Joda Time或者Python中的pytz。将UTC时间转换为本地时间或者将本地时间转换为UTC时间,然后存储到数据库中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值