java连接mysql时区修改_java连接mysql数据库时的时区设置问题(time_zone)

java在连接mysql数据库时,会由于时区设置不正确导致报以下的错误:

The server time zone value '???ú±ê×??±??' is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.

这种情况下可以修改数据库的时区。

解决方法有二:

一、命令行方式(临时性的解决)

使用管理员启动CMD,进入mysql数据库,输入命令:

show variables like "%time_zone%";

一般会得到以下结果:

+------------------+--------+

| Variable_name    | Value  |

+------------------+--------+

| system_time_zone |        |

| time_zone        | SYSTEM |

+------------------+--------+

2 rows in set, 1 warning (0.00 sec)

这时候输入命令

set global time_zone='+8:00';

设置完成后,重启mysql服务。

再次验证

show variables like "%time_zone%";

结果

+------------------+--------+

| Variable_name    | Value  |

+------------------+--------+

| system_time_zone |        |

| time_zone        | +08:00 |

+------------------+--------+

2 rows in set, 1 warning (0.00 sec)

重新运行java程序即可正确连接数据库。

二、修改my.ini下的【mysqld】(永久解决)

打开my.ini在【mysqld】下增加一句

default-time_zone = ‘+8:00’

保存退出后。重启MySQL服务。

然后使用java程序即可连接mysql数据库。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值