zoukankan      html  css  js  c++  java
  • Java项目 MySQL5.x迁移到MySQL8.x

    MySQL 8.0 开始数据库相比常用的 5.X 版本发生了比较大的变化,想要在已有Java MySQL5.x项目迁移到MySQL8.x,利用 mysql-connector-java 与 MySQL 8.X 版本建立连接,有以下四个方面与 MySQL 5.X 版本相比发生了变化:

    1、MySQL 8.0 以上版本驱动包版本 mysql-connector-java-8.X.jar,jar包下载地址:https://dev.mysql.com/downloads/connector/j/

      MySQL 版本和 mysql-connector-java 版本对应关系如下,MySQL官方也是推荐使用  mysql-connector-java-8.X.jar 去连接 MySQL 8.0 的版本

    Connector/J versionDriver TypeJDBC versionMySQL Server versionStatus
    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 

    5、原先Java项目中使用的mysql-connector-java-5.X.jar要去掉,不能和mysql-connector-java-8.X.jar一同使用。


    例子
     Class.forName("com.mysql.cj.jdbc.Driver");
     conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/test_demo?useSSL=false&serverTimezone=UTC","root","password");

    参考:https://www.cnblogs.com/jyroy/p/11276152.html

  • 相关阅读:
    能大大提升工作效率和时间效率的9个重要习惯
    hibernate的校验
    8. semahpore原理
    chklist
    android textview 自动换行 整齐排版
    fiddler接口测试,js代码修改日志展示(埋点用)
    Python模块之 tqdm进度条
    Python抓取网页到本地
    Python模块之 clint 进度条
    python windows下pip安装错误whl文件安装错误
  • 原文地址:https://www.cnblogs.com/wangle1001986/p/13503602.html
Copyright © 2011-2022 走看看