错误信息
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等等