MySQL 8.0.11 Community Server 与 驱动 mysql-connector-java-8.0.11.jar

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);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值