中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

Spring數(shù)據(jù)庫(kù)異常的示例分析

這篇文章給大家分享的是有關(guān)Spring數(shù)據(jù)庫(kù)異常的示例分析的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

創(chuàng)新互聯(lián)網(wǎng)站建設(shè)提供從項(xiàng)目策劃、軟件開(kāi)發(fā),軟件安全維護(hù)、網(wǎng)站優(yōu)化(SEO)、網(wǎng)站分析、效果評(píng)估等整套的建站服務(wù),主營(yíng)業(yè)務(wù)為網(wǎng)站建設(shè)、成都網(wǎng)站建設(shè),APP應(yīng)用開(kāi)發(fā)以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。創(chuàng)新互聯(lián)深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!

數(shù)據(jù)庫(kù)為:H2

Spring數(shù)據(jù)庫(kù)異常的示例分析

如果需要處理特定 SQL 異常,比如 SQL 語(yǔ)句錯(cuò)誤,這個(gè)時(shí)候我們應(yīng)該怎么辦?

查看 SQLException 源碼,我們可以發(fā)現(xiàn)兩個(gè)重要的方法。

SQLException.getErrorCode:返回?cái)?shù)據(jù)庫(kù)特定的錯(cuò)誤碼,由數(shù)據(jù)庫(kù)廠商制定,不同廠商錯(cuò)誤碼不同。如重復(fù)主鍵錯(cuò)誤碼在 MySQL 中是 1062,而在 Oracle 中卻是 1。

SQLException.getSQLState:返回 XOPEN 或 SQL:2003 制定的錯(cuò)誤碼規(guī)范。數(shù)據(jù)庫(kù)廠商會(huì)將不同錯(cuò)誤消息映射成同一個(gè)錯(cuò)誤碼

所以我們可以根據(jù) SQLException.getErrorCode 處理相應(yīng)的數(shù)據(jù)庫(kù)異常。

Spring數(shù)據(jù)庫(kù)異常的示例分析

由于數(shù)據(jù)庫(kù)廠商錯(cuò)誤碼不相同,這就導(dǎo)致如果我們更換數(shù)據(jù)庫(kù),上面判斷邏輯就必須重寫(xiě)。

下面我們使用 Spring 操作數(shù)據(jù)庫(kù)。

Spring 操作數(shù)據(jù)庫(kù)

Spring數(shù)據(jù)庫(kù)異常的示例分析

使用 Spring 之后,我們不再需要強(qiáng)制捕獲異常。如果 SQL 語(yǔ)句運(yùn)行存在異常,Spring 會(huì)拋出其內(nèi)置特定的異常。如上面 SQL 語(yǔ)句異常將會(huì)拋出 BadSqlGrammarException。除了這個(gè)異常之外,Spring 還定義很多數(shù)據(jù)庫(kù)異常。

Spring數(shù)據(jù)庫(kù)異常的示例分析

每個(gè) Spring 數(shù)據(jù)庫(kù)異常的基類都是 DataAccessException。由于 DataAccessException 繼承自 RuntimeException,所以在這類異常無(wú)需強(qiáng)制捕獲。

在 Spring 中使用 SQLExceptionTranslator 進(jìn)行異常轉(zhuǎn)換,默認(rèn)的轉(zhuǎn)換規(guī)則會(huì)根據(jù) SQLException.getErrorCode 返回的錯(cuò)誤碼進(jìn)行相應(yīng)的轉(zhuǎn)換。

下面我們從源碼分析轉(zhuǎn)換過(guò)程。

實(shí)現(xiàn)細(xì)節(jié)

調(diào)試 JdbcTemplate 的源碼。

Spring數(shù)據(jù)庫(kù)異常的示例分析

可以看到這里捕獲了 SQLException,轉(zhuǎn)換之后再將其拋出。

整個(gè)轉(zhuǎn)換過(guò)程,最后交給 SQLExceptionTranslator 進(jìn)行轉(zhuǎn)換。

首先我們查看 SQLExceptionTranslator 類圖。

Spring數(shù)據(jù)庫(kù)異常的示例分析

可以看到其實(shí)現(xiàn)了一個(gè)抽象類以及三個(gè)子類。

Spring數(shù)據(jù)庫(kù)異常的示例分析

抽象類中會(huì)首先會(huì)使用子類轉(zhuǎn)換,若未能轉(zhuǎn)換成功,將會(huì)啟動(dòng) fallback機(jī)制,再次轉(zhuǎn)換,作為兜底。

接著我們先看下三個(gè)子類的區(qū)別。

SQLErrorCodeSQLExceptionTranslator:

默認(rèn)轉(zhuǎn)換類主要根據(jù) SQLException.getErrorCode 進(jìn)行轉(zhuǎn)換。默認(rèn)使用 SQLExceptionSubclassTranslator 作為 fallback 對(duì)象。

SQLExceptionSubclassTranslator:

基于 JDBC 的 SQLException 標(biāo)準(zhǔn)子類判斷,如 java.sql.SQLTransientException。使用 SQLStateSQLExceptionTranslator 作為 fallback 對(duì)象。

SQLStateSQLExceptionTranslator:

基于 SQLException.getSQLState 規(guī)則判斷。

下面分析 SQLErrorCodeSQLExceptionTranslator ,其他兩個(gè)比較類似,同學(xué)們可以自己看源碼分析。

SQLErrorCodeSQLExceptionTranslator 轉(zhuǎn)換器主要根據(jù) SQLException.getErrorCode 進(jìn)行判斷。Spring 默認(rèn)在 org/springframework/jdbc/support/sql-error-codes.xml 歸納不同數(shù)據(jù)庫(kù)廠商相關(guān)錯(cuò)誤碼。該配置文件會(huì)在第一次發(fā)生 SQL 異常時(shí)由 SQLErrorCodesFactory 進(jìn)行加載,最后生成 SQLErrorCodes。

Spring數(shù)據(jù)庫(kù)異常的示例分析

另外在 SQLErrorCodes 提供擴(kuò)展方法,可以根據(jù)錯(cuò)誤碼轉(zhuǎn)換成自定義的異常。

最后查看 SQLErrorCodeSQLExceptionTranslator 里的轉(zhuǎn)換方法。

Spring數(shù)據(jù)庫(kù)異常的示例分析

前三個(gè)方法是 Spring 留下擴(kuò)展方法,可以根據(jù)自己需求分別擴(kuò)展。若都沒(méi)有實(shí)現(xiàn),將會(huì)根據(jù)錯(cuò)誤碼判斷轉(zhuǎn)換成具體的異常。

Spring數(shù)據(jù)庫(kù)異常的示例分析

自定義異常轉(zhuǎn)換

上面說(shuō)到 Spring 總共給我們留下三處擴(kuò)展點(diǎn)。

繼承 SQLErrorCodeSQLExceptionTranslator,重寫(xiě) customTranslate。繼承 SQLExceptionTranslator,重寫(xiě) translate,然后在 sql-error-codes.xml注入。使用 SQLErrorCodes#customTranslations ,然后在 sql-error-codes.xml 配置相關(guān)錯(cuò)誤碼轉(zhuǎn)換的規(guī)則。

第三種方式改動(dòng)最小,比較簡(jiǎn)單。首先在 classpath 下生成 sql-error-codes.xml,復(fù)制原有配置,最后配置 customTranslations 。

Spring數(shù)據(jù)庫(kù)異常的示例分析

這里需要注意的是,需要轉(zhuǎn)化的異常類型必須為 DataAccessException 子類。下面面我們自定義一個(gè)異常。

Spring數(shù)據(jù)庫(kù)異常的示例分析

總結(jié)

Spirng 異常處理將 SQL 異常轉(zhuǎn)化成內(nèi)置異常,屏蔽不同數(shù)據(jù)庫(kù)返回碼不一致的帶來(lái)的問(wèn)題。

最后總結(jié)本文的知識(shí)點(diǎn),希望幫助到大家。

Spring數(shù)據(jù)庫(kù)異常的示例分析

感謝各位的閱讀!關(guān)于“Spring數(shù)據(jù)庫(kù)異常的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

本文標(biāo)題:Spring數(shù)據(jù)庫(kù)異常的示例分析
標(biāo)題鏈接:http://www.rwnh.cn/article30/ghcjso.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)站維護(hù)網(wǎng)站建設(shè)、服務(wù)器托管、全網(wǎng)營(yíng)銷推廣

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化
淳安县| 台北市| 金坛市| 长宁区| 常州市| 大石桥市| 朝阳县| 芦溪县| 怀集县| 呼玛县| 永仁县| 开化县| 绵竹市| 丰顺县| 宁德市| 海宁市| 承德县| 津市市| 喀喇沁旗| 衡东县| 隆尧县| 宜丰县| 武功县| 高青县| 江达县| 会昌县| 虞城县| 克什克腾旗| 元江| 诸城市| 姜堰市| 板桥市| 临湘市| 比如县| 闵行区| 内江市| 剑阁县| 毕节市| 塔城市| 赤城县| 镇赉县|