a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數(shù)據(jù)庫 > Oracle > 正文

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

2024-08-29 13:52:24
字體:
供稿:網(wǎng)友
需求:業(yè)務邏輯在處理數(shù)據(jù)時,需要返回Message并阻止程序的繼續(xù)運行。但是,在存儲過程使用Oracle數(shù)據(jù)庫的Raise根本無法滿足現(xiàn)在的要求。

解決方法:

使用RAISE_application_ERROR

RAISE_APPLICATION_ERROR ( error_number_in IN NUMBER, error_msg_in IN VARCHAR2);

error_number: 自定義的錯誤編號。

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

在使用的過程中,你可能會遇到了下面的問題。

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

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

在存儲過程中定義的錯誤代碼Number其實并不在Oracle數(shù)據(jù)庫所允許的范圍之內(nèi)。因為Oracle數(shù)據(jù)庫允許自定義的錯誤代碼的范圍是-20000 -- -20999

這樣,就在java端可以通過SQLException來捕獲異常。

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

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

下面我們來介紹另一種解決方法:

通過存儲過程返回值,你可以直接把錯誤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)用存儲過程的步驟

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

// 從result中解析出Message_id,顯示Message到前臺


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 欧美日韩一区二区在线 | 欧美在线播放一区二区三区 | 久久不卡日韩美女 | 97超碰网| 国产91视频一区二区 | 不卡av在线 | 成人在线不卡 | 午夜精品一区二区三区在线播放 | 夜本色 | 中文字幕在线资源 | 亚洲国产精品久久久久秋霞不卡 | 中文字幕第90页 | 久久综合精品视频 | 成人1区 | 美女久久精品 | 欧美成人一区二区三区片免费 | 国产亚洲综合一区二区 | 欧美亚洲国产一区 | 久久国产一区二区 | 黄色一级毛片 | 久久99精品国产麻豆婷婷洗澡 | 另类 综合 日韩 欧美 亚洲 | 国产精品久久国产精品99 gif | 成人不卡在线 | 欧美激情欧美激情在线五月 | 中文字幕一区在线观看视频 | 久久精品这里热有精品 | 亚洲一区 中文字幕 | 久久亚洲精品国产亚洲老地址 | 一区二区在线免费观看 | 在线日本视频 | 欧美在线视频一区二区 | 成人免费一区二区三区视频网站 | 岛国av免费看 | 国产一区二区在线观看视频 | 狠狠爱www人成狠狠爱综合网 | 亚洲毛片在线 | 日韩成人 | 日韩国产在线 | 日韩av在线一区二区 | 国产一区二区在线播放 |