MySQL 8.0.11
1. 遇见问题
MySQL8.0.11 Community Server 与 mysql-connector-java-5.1.37.bin.jar结合使用,代码及配置没有问题,但是下面代码无论如何都链接不上数据库(代码在别人那里可用 MySQL5.xxx 与 mysql-connector-java-5.1.37.bin.jar)
Connection connection = DriverManager.getConnection(url,username,password);
2. 发现
MySQL 8.0 开始数据库相比常用的 5.X 版本还是有一些变化。
总结一下,想要利用 mysql-connector-java-8.xxx.jar 与 MySQL 8.X 版本建立连接,有以下几个方面与 MySQL 5.X 版本相比发生了变化。
3. 解决方式
1. 驱动的加载方式
mysql-connector-java-5.xxx.jar的加载方式
//第一种(加载两次驱动,一般情况不会去用了)
DriverManager.registerDriver(new Driver());
//第二种
Class.forName("com.mysql.jdbc.Driver");
mysql-connector-java-8.xxx.jar的加载方式
Class.forName("com.mysql.cj.jdbc.Driver");
2. MySQL 8.0 以上版本不需要建立 SSL 连接的,需要显式关闭。还需要设置 CST->也就是设置时区。
MySQL 5.7 之前版本,安全性做的并不够好,比如安装时生成的root空密码账号、存在任何用户都能连接上的 test 库等,导致数据库存在较大的安全隐患。从5.7版本开始MySQL官方对这些问题逐步进行了修复,到了 MySQL 8.0 以上版本已经不需要使用 SSL 进行连接加密了。但是高版本仍然保留了这个接口,所以需要在连接的时候手动写明是否需要进行 SSL 连接,这里我们手动关闭 SSL 连接加密就OK。
mysql-connector-java-5.xxx.jar的配置方式
//配置文件
//url=jdbc:数据库名称(mysql/Oracle)://数据库所在机器ip:数据库端口/数据库(database)
url=jdbc:mysql://localhost:3306/test
username=root
password=root
//java代码
Connection connection = DriverManager.getConnection(url,username,password);
mysql-connector-java-8.xxx.jar的配置方式
//配置文件
url=jdbc:mysql://localhost:3306/test?useSSL=false&serverTimezone=UTC
username=root
password=root
//java代码
Connection connection = DriverManager.getConnection(url,username,password);