数据库MYSQL时区的问题

数据库MYSQL时区的问题

问题描述

在java后端用new Date()生成的时间,保存到数据库中,往往时间总是比真实时间早8小时,比如 在java中是 2019-02-19 00:00:00,在数据库中看到的时间就是2019-02-18 16:00:00

解决办法

出现这种情况的原因,主要是数据库时区设置出现的问题,如果spring配置数据库时用的spring.datasource.url=jdbc:mysql://10.35.105.25:3306/database?characterEncoding=utf-8&serverTimezone=UTC,注意看,最后是serverTimezone=UTC,这里配置的意思是时区为UTC世界统一时间,而当代码中默认的是北京时间(东八区),就出现了时间差8个小时的情况。对于国内开发者,我们需要使用的都是北京时间,那我们只需要把数据库时区设置成spring.datasource.url=jdbc:mysql://10.35.105.25:3306/database?characterEncoding=utf-8&serverTimezone=GMT%2B8 就可以了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值