亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

講解Oracle數據庫自定義異常的使用方法

瀏覽:29日期:2023-11-29 08:01:56
需求:業務邏輯在處理數據時,需要返回Message并阻止程序的繼續運行。但是,在存儲過程使用Oracle數據庫的Raise根本無法滿足現在的要求。

解決方法:

使用RAISE_APPLICATION_ERROR

RAISE_APPLICATION_ERROR ( error_number_in IN NUMBER, error_msg_in IN VARCHAR2);

error_number: 自定義的錯誤編號。

error_msg:自定義的錯誤內容。

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

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

出現此錯誤的原因如下:

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

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

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

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

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

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

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

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

標簽: Oracle 數據庫
主站蜘蛛池模板: 善良的翁熄日本中文字幕1 上海麻豆文化传媒网站入口 | 国产片欧美片亚洲片久久综合 | 日本黄色免费网站 | 亚洲啪| 在线看免费的污 | 亚洲爆乳无码一区二区三区 | 国产线视频精品免费观看视频 | 朴妮唛禁福利视频在线 | 国产香港三级理论在线 | 夜恋秀场欧美成人影院 | 国产福利一区二区三区四区 | www.黄色网.com | 尤物视频免费观看 | bt7086 福利二区 最新合集 | 精品国产亚洲一区二区三区 | 欧美日本在线播放 | 国产成人精品高清在线 | 米奇精品一区二区三区 | 免费观看拍拍视频在线观看 | 日韩一区二区超清视频 | 国产自愉怕一区二区三区 | 国产成人在线免费视频 | 久久精品综合一区二区三区 | 国产在线丝袜 | 国产精品第一页第一页 | 婷婷视频在线 | 深夜国产一区二区三区在线看 | 国产欧美日韩不卡 | 欧美日韩国产高清一区二区三区 | 欧美三级在线观看不卡视频 | 33333在线亚洲 | 免费香蕉视频国产在线看 | 国产精品自产拍2021在线观看 | 国产一区二区高清 | 久久91精品国产99久久yfo | 亚洲欧美综合乱码精品成人网 | 曰本一级毛片免费播放 | 国产一区中文字幕 | 国产综合欧美日韩视频一区 | 欧美精品首页 | 香蕉视频在线观看视频 |