青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

異常處理

?

當異常生成之后,程序被中止,控制權(quán)交給異常處理模塊,異常處理模塊捕獲當前異常句柄,并交由相應(yīng)的程序處理;如果,異常促里模塊沒有捕捉到異常句柄,那么它將被傳輸?shù)疆斍俺绦虻耐鈬?/span>

?

除非由一些特殊的要求,一般情況下異常將再當前程序的異常處理模塊中被處理。異常處理模塊以 EXCEPTION 開始 END; 結(jié)尾。

?????? Declare

?????? ?????? /*…………*/

?????? begin

?????? ?????? /*…………*/

?????? exception

????????????? when /* 異常名稱 */

????????????? then /* 異常處理 */

????????????? when other

????????????? then /* 異常處理 */

?????? end;

異常處理模塊的語法基本上以 CASE 一致,凡是在 when 中有定義的異常都將被處理,而沒有的則被傳輸。一個特殊的異常處理語句是 WHEN OTHERS 。就想在( 3 )中所說的,它會處理所有為被處理的異常,因此必須小心使用它,最好是在最外層的程序中。當然如果喜歡偷懶的,大可以在異常處理模塊中只放一個 OTHERS 。注意,無論哪種情況, OTHERS 只能這只在異常處理的最后一位。

?

有趣的是,可以在一個 when 中處理多個異常句柄。

?????? Exception

????????????? When no_data_found or invalid_employee_id or dbms_ldap.invalid session

????????????? Then /*………..*/

?????? End;

?????? /

在這個例子里,有標準包的異常、自定義異常和非標準包中的異常。這些異常只能用 or 連接,不可以用 and ,因為只有一個異常能夠生成。

?

raise_application_error 生成的異常,如果沒有被處理而一直傳遞到系統(tǒng)環(huán)境中,那么環(huán)境將視情況作出相應(yīng)的反映。在 sqlplus 中, oracle 將回滾所有 DML 對數(shù)據(jù)所做的修改。在 sqlplus 環(huán)境中,因為有自動回滾的存在,我們可以保留出現(xiàn)未被處理的異常的可能性;而在另外的一些環(huán)境中,則需要仔細設(shè)計最外層程序。

ü???????? 捕捉任何有可能傳出的異常。

ü???????? 記錄錯誤以便于分析。

ü???????? 給外部環(huán)境一個信息,以便于其作出相應(yīng)的處理。

?

對于自定義異常,因為 sqlcode 值永遠是 1 ,所以當它被傳出時,如果外圍程序中沒有定義相同名稱的異常,我們將不知道是什么異常產(chǎn)生了。因此,不要將自定義異常傳遞出去。

?

在程序中處理幾個互相獨立的操作時,為了避免出現(xiàn)因為一個操作產(chǎn)生異常而使整個程序被中斷的情況,有必要將這些獨立的操作放在各自的虛擬塊中。

?????? Procedure change_data is

?????? Begin

????????????? Begin

????????????? ?????? Delete from employee where …..

?????? ?????? Exception

????????????? ?????? When others then null;

????????????? End;

?

????????????? Begin

????????????? ?????? Update company set …….

?????? ?????? Exception

When others then null;

????????????? End;

?

????????????? Begin

????????????? ?????? Insert into company_history select * from company where ….

?????? ?????? Exception

????????????? ?????? When others then null;

????????????? End;

?????? End;

?????? /

?

?

Pl/sql 提供了一些內(nèi)建的函數(shù)來幫助我們確定、分析異常。

?

SQLCODE

這個函數(shù)在前面有提到過,它是一個用于返回當前模塊中最近一次異常值的函數(shù),或者說是非入棧程序的異常值。打個比方:如果在當前程序的異常模塊中調(diào)用了另一個程序, oracle 將當前程序及相應(yīng)的環(huán)境變量(包括異常值)壓入系統(tǒng)棧;在被調(diào)用程序中生成了一個值為 1 的異常,那么 sqlcode 將返回 1 ;之后剛才的程序出棧, sqlcode 返回當前異常值。需要注意的是,不要在異常模塊之外使用它,這樣不會有任何意義。當沒有異常或在異常模塊之外使用時, SQLCODE 返回 0 ;返回值 1 是指自定義異常。

?

SQLERRM

接收異常值,返回相應(yīng)的長度不超過 512 字節(jié)的描述語。如果沒有傳入異常值,則返回當前異常描述。

?????? Begin

?????? ?????? Dbms_output.put_line( sqlerrm(-1403);

?????? End;

Sql>/

Ora-1403: no data found

在需要體構(gòu)長度超過 512 字節(jié)的描述時, oracle 建議使用 dbms_utility.format_error_stack 。顯然,用這個函數(shù)來判斷一個異常是否為系統(tǒng)異常是很有用的,如果不是的話,將返回以下兩種情況的一種。

如果是一個負數(shù):

?????? ora-nnnnn: message not found,; product=rdbms; facility=ora

如果是一個正數(shù):

?????? -nnnnn: non-oracle exception

?

DBMS_UTILITY.FORMAT_ERROR_STACK

返回當前異常相應(yīng)的描述,沒有字符長度限制。與 SQLCODE 相同的是,必須在異常處理模塊中使用。雖然名稱中有一個 stack 在,但通過它并不能知道異常的最初生成處,需要的話就必須使用 DBMS_UTILITY.FORMAT_ERROR_BACKTRACE

?

DBMS_UTILITY.FORMAT_ERROR_BACKTRACE

系統(tǒng)為最近一次生成的異常設(shè)置了一個棧,并跟蹤它的傳遞過程,而這個函數(shù)使用這個棧,然后返回該異常的整個傳遞過程。這個函數(shù)對錯誤的定位和實施下一步處理起著至關(guān)重要的作用。

?????? Create or replace procedure procl is

?????? Begin

?????? ?????? Dbms_output.put_line(‘running proc1’);

????????????? Raise no_data_found;

?????? End;

?????? /

?????? create or replace procedure proc2 is

?????? begin

?????? ?????? dbms_output.put_line(‘calling proc1’);

????????????? proc1;

?????? end;

?????? /

?????? create or replace procedure proc3 is

?????? begin

?????? ?????? dbms_output.put_line(‘calling proc2’);

????????????? proc2;

?????? exception

????????????? when no_data_found

????????????? then

????????????? ?????? dbms_output.put_line(‘error stack at top level’);

????????????? ?????? dbms_output.put_line(dbms_utility.format_error_backtrace);

?????? end;

?????? /

現(xiàn)在可以運行 proc3 來看看結(jié)果。

Sql>set serveroutput on;

Sql>begin

2???????????????????????? dbms_output.put_line(‘proc3->proc2->proc1 backtrace’);

3???????????????????????? proc3;

4???? end;

5???? /

??? Proc3 -> Proc2 -> Proc1 backtrace

??? calling proc2

??? calling proc1

??? running proc1

??? Error stack at top level:

??? ORA-06512: at "SCOTT.PROC1", line 4

??? ORA-06512: at "SCOTT.PROC2", line 5

ORA-06512: at "SCOTT.PROC3", line 4

事實上,每次異常的產(chǎn)生都將重置這個異常棧,只是最后一次從系統(tǒng)棧出棧的是最外層的程序塊,所以可以清楚地看到異常生成的整個過程。上面這個程序的執(zhí)行過程是這樣的:首先用 put_line 打印 Proc3 -> Proc2 -> Proc1 backtrace 調(diào)用 proc3 ,當前程序入棧 => 打印 calling proc2 ,調(diào)用 proc2 proc3 入棧 => 打印 calling proc1 ,調(diào)用 proc1 proc2 入棧 => 打印 running proc1 ,生成 no_data_found 異常,該異常被壓入異常棧中 =>? proc2 出棧,并檢測到來自第 5 行調(diào)用傳遞過來的異常,將它在此壓入異常棧 => proc3 出棧,并檢測到來自第 4 行調(diào)用傳遞過來的異常,將它在此壓入異常棧, dbms_utility.format_error_backtrace 將異常棧中信息反相打印出來 =>? 最外層程序出棧, end

以下是正確使用這個函數(shù)的一些注意事項:

ü???????? 在當前程序的異常處理模塊中調(diào)用這個函數(shù)。

ü???????? 避免在中間程序中使用異常處理模塊。

這樣異常就能被正確地傳輸?shù)阶钔鈱映绦蛑校⒋蛴〕鲞@個過程了。

Posted on 2006-10-25 16:26 艾凡赫 閱讀(3246) 評論(2)  編輯 收藏 引用 所屬分類: ORACLE

Feedback

# re: oracle-plsql 異常處理( 4 )   回復(fù)  更多評論   

2008-03-12 08:13 by 小魚
頂一下,寫的不錯

# re: oracle-plsql 異常處理( 4 ) [未登錄]  回復(fù)  更多評論   

2011-05-27 13:59 by 1
11
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美一区二区三区精品| 亚洲免费大片| 久久精品水蜜桃av综合天堂| 国产一区二区精品久久| 好吊日精品视频| 久久综合电影| 免费在线看一区| 一区二区欧美国产| 亚洲欧美在线高清| 亚洲成人在线| 一区二区三区精品久久久| 国产精品美女久久久久久2018| 久久成人综合视频| 麻豆精品一区二区av白丝在线| 日韩一区二区精品在线观看| 中文日韩电影网站| 一区二区三区中文在线观看| 亚洲欧洲一区二区在线播放 | 久久精品国产久精国产一老狼| 亚欧美中日韩视频| 亚洲久久在线| 性久久久久久久久| 99精品视频免费观看视频| 亚洲欧美日本另类| 亚洲欧洲精品一区| 午夜日本精品| 亚洲视频图片小说| 久久香蕉国产线看观看av| 亚洲综合视频1区| 免费日韩av片| 久久人人爽人人| 国产精品久久久久久久9999| 欧美激情一区二区三区在线| 国产欧美日本一区二区三区| 亚洲日本一区二区| 亚洲第一级黄色片| 亚洲与欧洲av电影| 中文精品视频| 欧美—级在线免费片| 免费成人性网站| 国产视频在线观看一区二区| 日韩视频一区| 亚洲精品四区| 美女脱光内衣内裤视频久久影院 | 一区二区三区在线视频观看| 亚洲一级黄色| 亚洲综合国产激情另类一区| 欧美精品在线播放| 亚洲国产精品久久久久婷婷884 | 亚洲电影激情视频网站| 欧美在线地址| 欧美在线视频二区| 国产精品区一区二区三区| 日韩一区二区高清| 亚洲素人在线| 欧美色视频日本高清在线观看| 亚洲国产精品www| 最近中文字幕mv在线一区二区三区四区 | 亚洲国产高清aⅴ视频| 久久超碰97中文字幕| 久久久久国产精品厨房| 国产视频在线观看一区二区三区 | 欧美成年人在线观看| 免费日韩视频| 亚洲国产成人在线| 欧美 日韩 国产精品免费观看| 久久综合网络一区二区| 国产综合色在线| 久久夜色撩人精品| 亚洲大胆女人| 99ri日韩精品视频| 欧美日韩亚洲一区二| 一区二区三区欧美| 欧美在线看片a免费观看| 国产综合香蕉五月婷在线| 久久久久国色av免费看影院| 欧美jizz19性欧美| 亚洲美女少妇无套啪啪呻吟| 欧美日韩一区二区三区高清| 亚洲一二三区精品| 久久在线免费| 99国产精品视频免费观看| 欧美视频中文一区二区三区在线观看| 亚洲永久网站| 老鸭窝91久久精品色噜噜导演| 亚洲日本va在线观看| 国产精品jizz在线观看美国| 欧美在线国产精品| 亚洲激情偷拍| 欧美在线电影| 亚洲美女精品久久| 国产精品亚洲精品| 久久永久免费| 亚洲一区免费观看| 欧美激情精品久久久久久黑人| 99精品热6080yy久久| 国产一区二区三区精品欧美日韩一区二区三区 | 一本久道久久综合狠狠爱| 欧美一区二区三区免费视| 狠狠色丁香婷婷综合| 欧美精品一二三| 久久国产日韩欧美| 日韩性生活视频| 美女诱惑一区| 亚洲欧美视频在线观看视频| 亚洲国产欧美另类丝袜| 国产精品亚洲一区二区三区在线| 美女主播一区| 欧美亚洲一区| 中文国产一区| 亚洲欧洲偷拍精品| 老鸭窝亚洲一区二区三区| 午夜激情久久久| 99精品欧美一区| 亚洲福利视频免费观看| 国产视频欧美视频| 国产精品久久久久久一区二区三区| 老司机免费视频一区二区三区| 香蕉久久精品日日躁夜夜躁| 一区二区三区欧美在线| 亚洲国产欧美一区二区三区同亚洲| 久久精品男女| 欧美一区激情| 午夜精品久久久久99热蜜桃导演| 99v久久综合狠狠综合久久| 亚洲第一主播视频| 在线不卡中文字幕| 国外成人在线视频网站| 国产三级精品三级| 国产欧美精品日韩精品| 国产精自产拍久久久久久| 亚洲国产裸拍裸体视频在线观看乱了中文 | 伊人成综合网伊人222| 国产日韩1区| 国产精品自拍一区| 国产乱码精品一区二区三区不卡| 欧美系列电影免费观看| 欧美日韩国产色综合一二三四| 欧美大片第1页| 欧美不卡一区| 欧美人妖另类| 欧美日韩在线精品| 欧美午夜电影网| 国产精品久久久久久久久免费桃花| 欧美日韩视频| 国产精品美女久久福利网站| 国产精品va在线| 国产女主播一区二区| 国产一区二区三区在线观看免费 | 欧美肥婆在线| 欧美区日韩区| 国产精品久久久久免费a∨大胸 | 欧美日韩精品一区二区天天拍小说 | 禁久久精品乱码| 亚洲激情国产| 亚洲一区二区精品| 亚洲欧美国产三级| 久久精品五月婷婷| 欧美成人精品在线观看| 亚洲黄色在线视频| 中文国产成人精品| 久久精品国产77777蜜臀 | 宅男噜噜噜66一区二区| 亚洲欧美在线免费观看| 久久天天狠狠| 欧美日韩第一区日日骚| 国产乱人伦精品一区二区| 黄色欧美成人| 一本色道久久| 久久九九全国免费精品观看| 欧美黑人国产人伦爽爽爽| 日韩一区二区久久| 久久精品人人| 欧美日韩亚洲一区二区| 好看的av在线不卡观看| 9久草视频在线视频精品| 久久爱另类一区二区小说| 欧美激情在线免费观看| 亚洲专区在线| 欧美肥婆在线| 狠狠色丁香婷婷综合久久片| 一本一本久久a久久精品综合麻豆| 欧美一区二区日韩| 亚洲区第一页| 久久精品九九| 国产精品视频成人| 一本色道婷婷久久欧美| 久久亚洲欧美| 亚洲综合日本| 欧美日韩综合在线| 亚洲激情在线观看| 久久精品久久99精品久久| 一本一道久久综合狠狠老精东影业| 久久久久久网| 国产日韩欧美综合在线| 亚洲一区二区成人| 亚洲日本激情| 欧美不卡福利| 亚洲国产精品va在线看黑人| 久久激情婷婷|