解决JDBC连接数据库MySQL出现的时区问题

JDBC出现The server time zone value’Öйú±ê׼ʱ¼ä’ is unrec问题
1.出现这个问题的原因 :

在安装mysql的时候时区设置的不正确, mysql默认的是美国的时区,而我们中国大陆要比他们迟8小时,采用+8:00格式

使用的数据库是MySQL,没有指定MySQL驱动版本的情况下它自动依赖的驱动是8.0.12很高的版本,这是由于数据库和系统时区差异所造成的,在jdbc连接的url后面加上serverTimezone=GMT即可解决问题,如果需要使用gmt+8时区,需要写成GMT%2B8,否则会被解析为空。再一个解决办法就是使用低版本的MySQL jdbc驱动,5.1.28不会存在时区的问题。
2.解决办法:
修改mysql的my.ini配置文件该文件一般在C:\Program Files\MySQL\MySQL Server 5.7或者C:\ProgramData\MySQL\MySQL Server 5.7目录下
在这里插入图片描述

找到这个文件之后,在[mysqld]节点下面加上下面这句话

default-time-zone=’+08:00’

在这里插入图片描述

然后记得重启MySQL的服务,打开cmd窗口登录MySQL执行show variables like ‘%time_zone%’;这句命令,

然后在mysql执行语句:

set global time_zone=’+8:00’;
在这里插入图片描述


版权声明:本文为weixin_45101989原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。