欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

分析MySQL拋出異常的幾種常見(jiàn)解決方式

 更新時(shí)間:2021年05月18日 15:00:26   作者:華為云開(kāi)發(fā)者社區(qū)  
在本文中,總結(jié)了開(kāi)發(fā)過(guò)程中最為常見(jiàn)的幾種 MySQL 拋出的異常以及如何解決,包括高版本驅(qū)動(dòng)的問(wèn)題、時(shí)區(qū)配置問(wèn)題、SSL 連接問(wèn)題等。于我個(gè)人而言,這一篇足以解決目前項(xiàng)目中所有遇到的MySQL問(wèn)題。同時(shí),也希望本文能對(duì) MySQL 數(shù)據(jù)庫(kù)初學(xué)者有一定的引導(dǎo)入門(mén)作用。

前言

報(bào)錯(cuò)如下:

Could not open JDBC Connection for transaction; nested exception is java.sql.SQLException: Connections could not be acquired from the underlying database!  

對(duì)于此類(lèi)錯(cuò)誤,直接看釋義,一句話(huà):JDBC 驅(qū)動(dòng)拋出異常,連不上數(shù)據(jù)庫(kù)。

一、代碼配置的數(shù)據(jù)庫(kù)名稱(chēng)或者密碼與本地?cái)?shù)據(jù)庫(kù)不一致

1.1、錯(cuò)誤產(chǎn)生描述

第一種,也是最為常見(jiàn)的一種錯(cuò)誤:代碼配置的數(shù)據(jù)庫(kù)名稱(chēng)或者密碼與本地?cái)?shù)據(jù)庫(kù)不一致,拋出異常。

如上圖所示,在配置文件中,前面的 name 屬性是默認(rèn)的,無(wú)需改變,對(duì)于用戶(hù)名,一般為 root,可以通過(guò)數(shù)據(jù)庫(kù)管理軟件直接查看本地配置的情況,數(shù)據(jù)庫(kù)的密碼就是你自己設(shè)置的了。

1.2、解決方式

修改配置文件對(duì)應(yīng)的名稱(chēng)和密碼。

二、導(dǎo)入的非本地項(xiàng)目文件與本地的數(shù)據(jù)庫(kù)版本不匹配

2.1、錯(cuò)誤產(chǎn)生描述

第二種常見(jiàn)的錯(cuò)誤:使用 IDE(以 Eclipse 為例)導(dǎo)入的非本地項(xiàng)目文件與本地的數(shù)據(jù)庫(kù)版本不匹配。

舉個(gè)例子:你導(dǎo)入你 eclipse 中的項(xiàng)目里面依賴(lài)的 jar 包是 8.0 的版本,而你本地安裝的是 5.0 的 MySQL 數(shù)據(jù)庫(kù),自然報(bào)錯(cuò)。

2.2、解決方式

在你導(dǎo)入的項(xiàng)目中找到 Referenced Libraries,右擊鼠標(biāo)→Build Path→Configure Build Path…Remove 掉項(xiàng)目里面依賴(lài)的 8.0 的 MySQL 驅(qū)動(dòng),Add 進(jìn)你本地安裝的 5.0 的版本即可。

三、MySQL 高版本配置加載驅(qū)動(dòng)類(lèi)包出錯(cuò)問(wèn)題(以 MySQL 8.0 為例)

這個(gè)錯(cuò)誤是由于 MySQL 版本更新之后,驅(qū)動(dòng)包發(fā)生改變導(dǎo)致的,新的驅(qū)動(dòng)程序類(lèi)是 com.mysql.cj.jdbc.Driver。

3.1、錯(cuò)誤產(chǎn)生描述

報(bào)錯(cuò)如下:

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.

錯(cuò)誤說(shuō)明:不建議使用驅(qū)動(dòng)類(lèi)'com.mysql.jdbc.Driver'。新的驅(qū)動(dòng)程序類(lèi)是'com.mysql.cj.jdbc.Driver',驅(qū)動(dòng)程序是通過(guò) SPI 自動(dòng)注冊(cè)的,通常是不需要手動(dòng)加載驅(qū)動(dòng)類(lèi)。

3.2、解決方式

將 MySQL 數(shù)據(jù)庫(kù) 5.0 使用的驅(qū)動(dòng)類(lèi)com.mysql.jdbc.Driver改為com.mysql.cj.jdbc.Driver,驅(qū)動(dòng)程序是通過(guò) SPI 自動(dòng)注冊(cè)的,通常是不需要手動(dòng)加載驅(qū)動(dòng)類(lèi)。修改之后的配置文件如下圖所示:

<!-- 加載數(shù)據(jù)庫(kù)驅(qū)動(dòng) -->
<property name="driverClass" value="com.mysql.cj.jdbc.Driver"></property>

3.3、MySQL 不同版本的驅(qū)動(dòng)類(lèi)如何查看

對(duì)于 MySQL 的驅(qū)動(dòng)類(lèi),我們對(duì)每個(gè)版本進(jìn)行查看時(shí),點(diǎn)開(kāi)驅(qū)動(dòng)的 jar 包可以直接查看驅(qū)動(dòng)是位于哪里,例如 8.0 版本的就是 com.mysql.cj.jdbc.Driver,如下圖所示:

四、數(shù)據(jù)庫(kù)連接字符串高版本配置出錯(cuò)(時(shí)區(qū)問(wèn)題)

注意:MySQL 6.0 版本之后都需要配置時(shí)區(qū)。

4.1、錯(cuò)誤產(chǎn)生描述

報(bào)錯(cuò)如下:

2020-01-14 00:45:30,876 ERROR [DruidDataSource.java:616] : init datasource error 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.

4.2、解決方式

我們可以利用時(shí)區(qū)支持,通過(guò)配置服務(wù)器或 JDBC 驅(qū)動(dòng)程序(通過(guò) serverTimezone 配置屬性)以使用更具體的時(shí)區(qū)值。

配置文件如下:

<!-- 數(shù)據(jù)庫(kù)連接字符串 -->
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/demo?serverTimezone=GMT%2B8&amp;characterEncoding=utf-8"></property>

五、為什么數(shù)據(jù)庫(kù)中寫(xiě)入數(shù)據(jù)相差 8 個(gè)小時(shí)?

5.1、錯(cuò)誤產(chǎn)生描述

Java 數(shù)據(jù)庫(kù)連接使用 UTC 時(shí)區(qū)(世界標(biāo)準(zhǔn)時(shí)間),即 serverTimezone=UTC,而北京時(shí)間比 UTC 時(shí)間早8小時(shí),即 UTC+08:00,如果我們直接使用 serverTimezone=UTC,寫(xiě)入數(shù)據(jù)庫(kù)中的數(shù)據(jù)會(huì)提前 8 個(gè)小時(shí)。如果按照如下配置就會(huì)在數(shù)據(jù)庫(kù)中寫(xiě)入數(shù)據(jù)相差 8 個(gè)小時(shí):

<!-- 數(shù)據(jù)庫(kù)連接字符串 -->
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/demo?serverTimezone=UTC&amp;characterEncoding=utf-8"></property>

5.2、解決方式

我們可以修改設(shè)置 serverTimezone 為北京時(shí)間 GMT%2B8、上海時(shí)間 Asia/Shanghai 或者香港時(shí)間 Hongkong。

配置文件如下即可:

<!-- 數(shù)據(jù)庫(kù)連接字符串 -->
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/demo?serverTimezone=GMT%2B8&amp;characterEncoding=utf-8"></property>

另外在 MySQL 中的 my.ini 配置文件也可以修改,此文章僅用于解決相應(yīng)問(wèn)題,故不多做詳細(xì)描述。

六、SSL 連接問(wèn)題

6.1、錯(cuò)誤產(chǎn)生描述

報(bào)錯(cuò)如下:

Sun Oct 14 00:45:30 CST 2018 WARN: 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.

錯(cuò)誤說(shuō)明:不建議在沒(méi)有服務(wù)器身份驗(yàn)證的情況下建立 SSL 連接。根據(jù) MySQL 5.5.45+,5.6.26+ 和 5.7.6+ 的 SSL 連接要求,如果未設(shè)置連接方式,則默認(rèn)情況下必須建立 SSL 連接。對(duì)于不使用 SSL 的現(xiàn)有應(yīng)用程序,服務(wù)器的驗(yàn)證證書(shū)屬性設(shè)置為“false”。您需要通過(guò)設(shè)置useSSL = false來(lái)顯式禁用 SSL,或者設(shè)置useSSL = true并提供服務(wù)器的驗(yàn)證證書(shū)。

6.2、解決方式

  • 數(shù)據(jù)庫(kù) URL 連接地址添加useSSL = false,適用于測(cè)試。
  • 數(shù)據(jù)庫(kù) URL 連接地址添加useSSL = true,并且提供服務(wù)器的驗(yàn)證證書(shū)。

配置文件如下即可:

 <!-- 數(shù)據(jù)庫(kù)連接字符串 -->
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/demo?useSSL=false&amp;serverTimezone=GMT%2B8&amp;characterEncoding=utf-8"></property>

總結(jié)

通過(guò)對(duì)于 MySQL 拋出異常的幾種常見(jiàn)解決方式的總結(jié),加深對(duì)于 MySQL 底層的了解。只要是干開(kāi)發(fā),錯(cuò)誤是不斷地,要善于總結(jié)。同時(shí),要充分掌握開(kāi)發(fā)的底層原理,不同的版本迭代作為開(kāi)發(fā)者要及時(shí)了解,不然永遠(yuǎn)跟不上技術(shù)的發(fā)展。

以上就是分析MySQL拋出異常的幾種常見(jiàn)解決方式的詳細(xì)內(nèi)容,更多關(guān)于MySQL異常的解決方式的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 綠色版 mysql 安裝配置

    綠色版 mysql 安裝配置

    好多朋友對(duì)于mysql的配置不是很清楚,其實(shí)最新本的配置也是這樣的,建議大家到s.jb51.net去下載一些服務(wù)器軟件。
    2009-06-06
  • 淺析Mysql 中如何導(dǎo)出數(shù)據(jù)

    淺析Mysql 中如何導(dǎo)出數(shù)據(jù)

    MySQL中你可以使用SELECT…INTO OUTFILE語(yǔ)句來(lái)簡(jiǎn)單的導(dǎo)出數(shù)據(jù)到文本文件上,這篇文章給大家介紹了Mysql 中如何導(dǎo)出數(shù)據(jù),感興趣的朋友跟隨小編一起看看吧
    2023-11-11
  • JDBC鏈接mysql插入數(shù)據(jù)后顯示問(wèn)號(hào)的原因及解決辦法

    JDBC鏈接mysql插入數(shù)據(jù)后顯示問(wèn)號(hào)的原因及解決辦法

    這篇文章主要介紹了JDBC鏈接mysql插入數(shù)據(jù)后顯示問(wèn)號(hào)的原因及解決辦法的相關(guān)資料,需要的朋友可以參考下
    2016-04-04
  • MySQL啟動(dòng)失敗之MySQL服務(wù)無(wú)法啟動(dòng)的原因及解決

    MySQL啟動(dòng)失敗之MySQL服務(wù)無(wú)法啟動(dòng)的原因及解決

    這篇文章主要介紹了MySQL啟動(dòng)失敗之MySQL服務(wù)無(wú)法啟動(dòng)的原因及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • MySQL事件與觸發(fā)器專(zhuān)題精煉

    MySQL事件與觸發(fā)器專(zhuān)題精煉

    觸發(fā)器是SQLserver提供給程序員和數(shù)據(jù)分析員來(lái)保證數(shù)據(jù)完整性的一種方法,它是與表事件相關(guān)的特殊的存儲(chǔ)過(guò)程,事件是在?MySQL?5.1后引入的,有點(diǎn)類(lèi)似操作系統(tǒng)的計(jì)劃任務(wù),但是周期性任務(wù)是內(nèi)置在MySQL服務(wù)端執(zhí)行的
    2022-03-03
  • mysql 5.7.18 zip版安裝使用教程

    mysql 5.7.18 zip版安裝使用教程

    這篇文章主要為大家詳細(xì)介紹了mysql 5.7.18 zip版安裝使用教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • MySql在Mac上的安裝與配置詳解

    MySql在Mac上的安裝與配置詳解

    這篇文章主要介紹了MySql在Mac上的安裝配置,需要的朋友可以參考下
    2017-05-05
  • mysql 添加索引的實(shí)現(xiàn)步驟

    mysql 添加索引的實(shí)現(xiàn)步驟

    索引是一種用于提高查詢(xún)效率的數(shù)據(jù)結(jié)構(gòu),通過(guò)添加索引,可以加快數(shù)據(jù)的查找速度,本文主要介紹了mysql 添加索引的實(shí)現(xiàn)步驟,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-07-07
  • mysql并發(fā)控制原理知識(shí)點(diǎn)

    mysql并發(fā)控制原理知識(shí)點(diǎn)

    在本篇文章里小編給大家整理的是一篇關(guān)于mysql并發(fā)控制原理知識(shí)點(diǎn)內(nèi)容,需要的朋友們參考下吧。
    2020-02-02
  • MySQL日志管理和備份與恢復(fù)

    MySQL日志管理和備份與恢復(fù)

    這篇文章主要介紹了MySQL如何實(shí)現(xiàn)日志的管理,備份與恢復(fù),本文有一定的參考價(jià)值,感興趣的小伙伴可以參考閱讀
    2023-04-04

最新評(píng)論