Java連接MySQL8.0以上版本數據庫方式(將驅動改成新版本的解決辦法)


前言:本人因用mysql 8和驅動5導致數據庫的某些功能失效,打算將驅動改成8的,因此找的一篇文章,此文章完美的解決了我的問題,在此分享

 

MySQL 8.0 開始數據庫相比常用的 5.X 版本發生了比較大的變化,我們在連接數據庫的過程中許多地方也要發生一些變化。

總結一下,想要利用 mysql-connector-java 與 MySQL 8.X 版本建立連接,有以下四個方面與 MySQL 5.X 版本相比發生了變化。

 

1、MySQL 8.0 以上版本驅動包版本 mysql-connector-java-8.X.jar

  MySQL 版本和 mysql-connector-java 版本對應關系如下,MySQL官方也是推薦使用  mysql-connector-java-8.X.jar 去連接 MySQL 8.0 的版本

Connector/J version Driver Type JDBC version MySQL Server version Status
5.1 4 3.0, 4.0, 4.1, 4.2 5.6*, 5.7*, 8.0* General availability
8.0 4 4.2 5.6, 5.7, 8.0 General availability. Recommended version

  

2、com.mysql.jdbc.Driver 更換為 com.mysql.cj.jdbc.Driver。

 

3、MySQL 8.0 以上版本不需要建立 SSL 連接的,需要顯式關閉。

  MySQL 5.7 之前版本,安全性做的並不夠好,比如安裝時生成的root空密碼賬號、存在任何用戶都能連接上的 test 庫等,導致數據庫存在較大的安全隱患。從5.7版本開始MySQL官方對這些問題逐步進行了修復,到了 MySQL 8.0 以上版本已經不需要使用 SSL 進行連接加密了。但是高版本仍然保留了這個接口,所以需要在連接的時候手動寫明是否需要進行 SSL 連接,這里我們手動關閉 SSL 連接加密就OK。

useSSL=false

 

 

4、最后還需要設置 CST。也就是設置時區。

 

 serverTimezone=UTC

 

 

例子
1 Class.forName("com.mysql.cj.jdbc.Driver");
2 conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/test_demo?useSSL=false&serverTimezone=UTC","root","password");
.xml配置:"jdbc:mysql://localhost:3306/mybatis?useSSL=true&serverTimezone=UTC&useUnicode=true&characterEncoding=UTF-8"

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM