关于mysql-connector-java(JDBC驱动)的一些坑
2017-07-28 17:18
453 查看
最近在写一个项目的时候,用了maven仓库里面较新的mysql的JDBC驱动,版本是6.0.6,Mybatis的全局配置是这么写的:
但是却发现报错了,错误原因是:
Error querying database. Cause: 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 specifc time zone value if you want to utilize time zone support.
这是因为在访问数据库时无法识别时区(我选择死亡(╬▔皿▔)凸),所以我们需要把JDBC的url值改为这样:
这里要注意了,我们编译一下项目发现出现了这样的错误:
Error creating document instance. Cause: org.xml.sax.SAXParseException; lineNumber: 11; columnNumber: 119; 对实体 "serverTimezone" 的引用必须以 ';' 分隔符结尾。
这里其实是因为xml把&作为一个特殊符号处理了(我选择再次死亡(╬▔皿▔)凸),所以我们需要把&替换为&这样就不会报错了。
当然我们也可以直接修改mysql的时区,打开mysql,输入set global time_zone='+8:00';
解决了这个问题之后,我们继续回到配置文件,我们再编译一下项目,这次错误倒是没有了,但是还有一些警告,虽然我们一般忽略警告,但是看起来还是挺不舒服的,所以解决一下吧。其中一个警告是这样的:
Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.
这是因为mysql的JDBC驱动使用了新的包名,所以我们需要将driver的值改为com.mysql.cj.jdbc.Driver
还有一个警告是这样的:
Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.
因为新版本的MySQL要求是否进行ssl连接,所以我们需要设置useSSL=false或者useSSL=true。
接下来,我们再编译一遍项目,总算0 error, 0 warning了。我们也能看到正确结果了。
<?xml version='1.0' encoding='UTF-8'?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <environments default=""> <environment id=""> <transactionManager type="JDBC"/> <dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8"/> <property name="username" value="root"/> <property name="password" value="root"/> </dataSource> </environment> </environments> <mappers> <mapper resource="sqlmap/User.xml"/> </mappers> </configuration>
但是却发现报错了,错误原因是:
Error querying database. Cause: 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 specifc time zone value if you want to utilize time zone support.
这是因为在访问数据库时无法识别时区(我选择死亡(╬▔皿▔)凸),所以我们需要把JDBC的url值改为这样:
<property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8&serverTimezone=UTC"/>
这里要注意了,我们编译一下项目发现出现了这样的错误:
Error creating document instance. Cause: org.xml.sax.SAXParseException; lineNumber: 11; columnNumber: 119; 对实体 "serverTimezone" 的引用必须以 ';' 分隔符结尾。
这里其实是因为xml把&作为一个特殊符号处理了(我选择再次死亡(╬▔皿▔)凸),所以我们需要把&替换为&这样就不会报错了。
<property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8&serverTimezone=UTC"/>
当然我们也可以直接修改mysql的时区,打开mysql,输入set global time_zone='+8:00';
解决了这个问题之后,我们继续回到配置文件,我们再编译一下项目,这次错误倒是没有了,但是还有一些警告,虽然我们一般忽略警告,但是看起来还是挺不舒服的,所以解决一下吧。其中一个警告是这样的:
Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.
这是因为mysql的JDBC驱动使用了新的包名,所以我们需要将driver的值改为com.mysql.cj.jdbc.Driver
<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
还有一个警告是这样的:
Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.
因为新版本的MySQL要求是否进行ssl连接,所以我们需要设置useSSL=false或者useSSL=true。
<property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8&serverTimezone=UTC&useSSL=false"/>
接下来,我们再编译一遍项目,总算0 error, 0 warning了。我们也能看到正确结果了。
相关文章推荐
- 关于mysql-connector-java×××.jar(这是mysql连接jdbc驱动的一个包)缺失造成Unable to load driver.
- mysql4.1.10的JDBC驱动(mysql-connector-java-3.1.7-bin.jar)的配置及测试
- hive ,sqoop使用的jdbc驱动版本(mysql-connector-java-5.1.23-bin.jar)影响hive使用
- mysql驱动配置:解决java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
- 编写操作数据库的JAVA程序时需要的连接MySQL数据库的JDBC连接包mysql-connector-java-5.1.10.zip怎么安装
- 关于oracle与mysql官方jdbc的一些区别
- JAVA JDBC(MySQL)驱动源码分析(一)
- MysqL驱动mysql-connector-java-5.1.5-bin.jar的位置
- JAVA JDBC(MySQL)驱动源码分析(二)
- MySQL的JDBC驱动 MySQL Connector/J
- Apache Tomcat/6.0.39如何配置连接mysql,JDBC:mysql-connector-java-5.1.30-bin.jar-成功连接心得
- Mysql Java驱动代码阅读笔记及JDBC规范笔记
- SQL2000 关于 Java JDBC 驱动的安装和设定
- 关于oracle与mysql官方jdbc的一些区别
- 关于oracle与mysql官方jdbc的一些区别
- SQL2000 关于 Java JDBC 驱动的安装和设定
- JAVA JDBC(MySQL)驱动源码分析(四)
- MySQL的JDBC驱动 MySQL Connector/J
- 关于在windows环境下启动java工程提示类找不到,即com.mysql.jdbc.Driver的解决办法
- 关于MySQL的JDBC驱动的问题