国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

講解Oracle數(shù)據(jù)庫(kù)自定義異常的使用方法

瀏覽:61日期:2023-11-29 08:01:56
需求:業(yè)務(wù)邏輯在處理數(shù)據(jù)時(shí),需要返回Message并阻止程序的繼續(xù)運(yùn)行。但是,在存儲(chǔ)過(guò)程使用Oracle數(shù)據(jù)庫(kù)的Raise根本無(wú)法滿(mǎn)足現(xiàn)在的要求。

解決方法:

使用RAISE_APPLICATION_ERROR

RAISE_APPLICATION_ERROR ( error_number_in IN NUMBER, error_msg_in IN VARCHAR2);

error_number: 自定義的錯(cuò)誤編號(hào)。

error_msg:自定義的錯(cuò)誤內(nèi)容。

在使用的過(guò)程中,你可能會(huì)遇到了下面的問(wèn)題。

ORA-21000: error number argument to raise_application_error of [xxxx] is out of range

出現(xiàn)此錯(cuò)誤的原因如下:

在存儲(chǔ)過(guò)程中定義的錯(cuò)誤代碼Number其實(shí)并不在Oracle數(shù)據(jù)庫(kù)所允許的范圍之內(nèi)。因?yàn)镺racle數(shù)據(jù)庫(kù)允許自定義的錯(cuò)誤代碼的范圍是-20000 -- -20999

這樣,就在Java端可以通過(guò)SQLException來(lái)捕獲異常。

雖然通過(guò)SQLException.getMessage()可以捕獲到異常的內(nèi)容,但是這些內(nèi)容對(duì)于開(kāi)發(fā)比較有用。對(duì)于客戶(hù)來(lái)說(shuō),并不友好,也沒(méi)有多大意義。

通過(guò)SQLException.getErrorCode()可以捕獲到自定義的異常錯(cuò)誤編號(hào)。然后我們就可以通過(guò)這個(gè)錯(cuò)誤編號(hào),自定義相應(yīng)的Message內(nèi)容,返回給客戶(hù)。

下面我們來(lái)介紹另一種解決方法:

通過(guò)存儲(chǔ)過(guò)程返回值,你可以直接把錯(cuò)誤Message定義在返回值中間。在Java端解析后,可以直接取得Message代碼。

示例如下:

If condition then

p_result := 'ERR:MSG2061';

end if;

if substr(p_result, 1, 3) = 'ERR' then

ROLLBACK;

else

p_result = 'OK';

end if;

Java:略去中間的調(diào)用存儲(chǔ)過(guò)程的步驟

if(result != null && result.startsWith('ERR:'))

// 從result中解析出Message_id,顯示Message到前臺(tái)

主站蜘蛛池模板: 迭部县| 辽中县| 和田县| 伊金霍洛旗| 崇礼县| 钟祥市| 江阴市| 德阳市| 巫溪县| 昌吉市| 海原县| 泌阳县| 秦安县| 庆安县| 冕宁县| 彰武县| 浮梁县| 桂东县| 灵宝市| 星子县| 曲沃县| 新乐市| 勐海县| 缙云县| 吉林省| 施秉县| 永康市| 洪雅县| 林西县| 临夏县| 安溪县| 惠水县| 云霄县| 平凉市| 阳城县| 封开县| 彰化市| 沙湾县| 修水县| 蓝田县| 南平市|