午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

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

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

瀏覽:121日期:2023-11-29 08:01:56
需求:業(yè)務(wù)邏輯在處理數(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()可以捕獲到自定義的異常錯誤編號。然后我們就可以通過這個錯誤編號,自定義相應(yīng)的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到前臺

主站蜘蛛池模板: 四虎视频国产精品免费 | 国偷自拍| 日韩av视屏 | 日本中文字幕免费在线观看 | 一区二区三区蜜桃 | 中文字幕有码视频 | 欧美激精品 | 麻豆视频免费在线播放 | 在线视频这里只有精品 | 中国av在线 | 狠狠操在线观看 | 亚洲精品久久久久久久久 | 欧美黑人性爽 | 日本三级在线视频 | 99免费视频| 91在线视频免费观看 | 清纯唯美亚洲综合 | 亚洲一区二区三区在线播放 | 亚洲成人一区二区 | 丰满漂亮的日本岳 | 免费亚洲精品 | 午夜三级在线 | 蜜桃精品噜噜噜成人av | 91精品久久香蕉国产线看观看 | 一区二区美女 | 日韩一区二区视频在线观看 | 成人毛片视频免费看 | 香蕉视频成人 | 丝袜超碰| 偷拍女澡堂bbbbbccccc | 99色在线观看 | 国产成人精品一区二区三区网站观看 | 手机在线看a | 日日操免费视频 | 94久久 | www黄色网| 全部免费毛片在线播放一个 | 中文字幕网址在线 | 91免费看网站 | 国产日韩欧美综合 | 国产精品一二 |