mysql错误:java.sql.SQLException: The server time zone value ‘XXXX‘ is unrecognized or represents...

错误信息

java web 项目,控制台server异常信息如下
在这里插入图片描述

java.sql.SQLException: 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 specific time zone value if you want to utilize time zone support.
	at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:129)
	at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97)
	at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:89)
	at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:63)
	at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:73)
	at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:76)
	at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:836)
	at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:456)
	at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:246)
	at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:198)
	at java.sql.DriverManager.getConnection(DriverManager.java:664)
	at java.sql.DriverManager.getConnection(DriverManager.java:247)
	at com.kaikeba.util.DBUtil.getConn(DBUtil.java:38)
	at com.kaikeba.db.UserDaoImp.insert(UserDaoImp.java:15)
	at com.kaikeba.db.UserDaoImp.insert(UserDaoImp.java:8)
	at com.kaikeba.service.DBService.insertUser(DBService.java:14)
	at com.kaikeba.servlet.UserServlet.doPost(UserServlet.java:41)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:660)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
	……

Tomcat Localhost Log 异常信息如下:NullPointerException
在这里插入图片描述

原因查找

在这里插入图片描述
DBUtil.java 38行出了问题,说明数据库连接有问题,定位到db.properties文件
在这里插入图片描述

解决方法

在url后边加上 serverTimezone=UTC

url=jdbc:mysql://localhost:3306/doudizhu?serverTimezone=UTC

时区设置,不然会出现时差,
如果你设置serverTimezone=UTC,连接不报错,
但是我们在用java代码插入到数据库时间的时候却出现了问题。
比如在java代码里面插入的时间为:2018-06-24 17:29:56
但是在数据库里面显示的时间却为:2018-06-24 09:29:56
有了8个小时的时差
UTC代表的是全球标准时间 ,但是我们使用的时间是北京时区也就是东八区,领先UTC八个小时。

//北京时间东八区
serverTimezone=GMT%2B8
//或者使用上海时间
serverTimezone=Asia/Shanghai

改完后数据库中文乱码

在这里插入图片描述
解决方法:
数据库链接地址后配置参数 useUnicode和characterEncoding

url=jdbc:mysql://localhost:3306/kkbdb?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai

解决后:
在这里插入图片描述
其他参数:useSSL, zeroDateTimeBehavior, allowMultiQueries等等

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值