国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

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

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

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

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

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

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

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

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

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

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

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

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

主站蜘蛛池模板: 亚洲三级黄色片 | 特级毛片a级毛免费播放 | 亚洲最大情网站在线观看 | 美女把张开腿男生猛戳免费视频 | 成人国产一区二区三区 | 一级做a级爰片性色毛片视频 | 中文字幕一区中文亚洲 | 99这里只有精品66视频 | 兔子先生节目在线观看免费 | 国产成人福利美女观看视频 | 国产精品人伦久久 | 三级黄色免费网站 | 国产美女在线一区二区三区 | 久久草在线观看 | 日韩aⅴ在线观看 | 扒开两腿猛进入爽爽视频 | 能在线观看的一区二区三区 | 亚洲精品一区亚洲精品 | 国产成人精品三区 | 亚洲成a人v大片在线观看 | 久久99久久精品免费思思6 | 18视频免费网站 | 免费视频久久看 | 三级在线网站 | 九九成人| 一级做a爰片久久毛片欧美 一级做a爰片久久毛片人呢 | 九九精品免费视频 | 成人软件18免费网站 | 欧美成人午夜不卡在线视频 | 国产精品手机在线亚洲 | 男人毛片 | 91探花福利精品国产自产在线 | 亚洲天堂日韩在线 | 国产欧美日韩综合二区三区 | 欧美成人小视频 | 中文字幕一级毛片 | 免费网站看v片在线香蕉 | 欧美一级在线视频 | 国产网站黄 | 韩国在线精品福利视频在线观看 | 成人精品视频一区二区在线 |