定義異常捕獲類型及處理方法:html
DECLARE handler_action HANDLER FOR condition_value [, condition_value] ... statement handler_action: CONTINUE | EXIT | UNDO condition_value: mysql_error_code | SQLSTATE [VALUE] sqlstate_value | condition_name | SQLWARNING | NOT FOUND | SQLEXCEPTION
這裏面須要注意幾點:mysql
a、condition_value [,condition_value],這個的話說明能夠包括多種狀況(方括弧表示可選的),也就是一個handler能夠定義成針對多種狀況進行相應的 操做;另外condition_value能夠包括的值有上面列出來的6種:sql
一、mysql_error_code,這個表示mysql的錯誤代碼,錯誤代碼是一個數字,完成是由mysql本身定義的,這個值能夠參考mysql數據庫錯誤代碼及信息。數據庫
二、SQLSTATE [VALUE] sqlstate_value,這個同錯誤代碼相似造成一一對應的關係,它是一個5個字符組成的字符串,關鍵的地方是它從ANSI SQL和ODBC這些標準中引用過來的,所以更加標準化,而不像上面的error_code徹底是mysql本身定義給本身用的,這個和第一個相似也能夠 參考mysql數據庫錯誤代碼及信息。spa
三、condtion_name,這個是條件名稱,它使用DECLARE...CONDITION語句來定義,這個後面咱們會介紹如何定義本身的condition_name。code
四、SQLWARNING,表示SQLTATE中的字符串以‘01’起始的那些錯誤,好比Error: 1311
SQLSTATE: 01000
(ER_SP_UNINIT_VAR
)server
五、NOT FOUND,表示SQLTATE中的字符串以‘02’起始的那些錯誤,好比Error: 1329
SQLSTATE: 02000
(ER_SP_FETCH_NO_DATA
)htm
六、SQLEXCEPTION,表示SQLSTATE中的字符串不是以'00'、'01'、'02' 起始的那些錯誤,這裏'00'起始的SQLSTATE其實表示的是成功執行而不是錯誤,另外兩個就是上面的4和5的兩種狀況。blog
上面的6種狀況其實能夠分爲兩類:ip
一類就是比較明確的處理,就是對指定的錯誤狀況進行處理,包括一、二、3這三種方式;
另外一類是對對應類型的錯誤的 處理,就是對某一羣錯誤的處理,包括四、五、6這三種方式。這個是介紹了condition_value。另外還要注意的一個內容是MySQL在默認狀況 下(也就是咱們沒有定義處理錯誤的方法-handler)本身的錯誤處理機制:一、對於SQLWARNING和NOT FOUND的處理方法就是無視錯誤繼續執行,因此在遊標的例子裏面若是咱們沒有對repeat的條件判斷的那個值作個no_more_products=1的handler來處理,那麼循環就會一直下去。二、對於SQLEXCEPTION的話,其默認的處理方法是在出現錯誤的地方就終止掉了。
b、statement,這個比較簡單就是當出現某種條件/錯誤時,咱們要執行的語句,能夠是簡單的如 SET var = value這樣的簡單的語句,也能夠是複雜的多行的語句,多行的話可使用BEGIN ..... END這裏把語句包括在裏面(這個比如delphi裏面的狀況,注意到咱們的存儲過程也是多行的,因此也要BEGIN .... END)。
c、handler_action,這個表示當執行完上面的statement後,但願執行怎樣的動做,這裏包括CONTINUE、EXIT、UNDO, 表示繼續、退出、撤銷(暫時不支持)。這邊就是兩種動做,其實這兩種動做在上面也說過了,CONTINUE就是一個是SQLWARNING和NOT FOUND的默認處理方法,而EXIT就是SQLEXCEPTION的默認處理方法。
另:
condition_name:命名條件
MySQL error code或者SQLSTATE code的可讀性太差,因此引入了命名條件:
語法:
DECLARE condition_name CONDITION FOR condition_value condition_value: SQLSTATE [VALUE] sqlstate_value | mysql_error_code
使用:
# original DECLARE CONTINUE HANDLER FOR 1216 MySQL_statements; # changed DECLARE foreign_key_error CONDITION FOR 1216; DECLARE CONTINUE HANDLER FOR foreign_key_error MySQL_statements;
示例:
CREATE PROCEDURE sp_add_location (in_location VARCHAR(30), in_address1 VARCHAR(30), in_address2 VARCHAR(30), zipcode VARCHAR(10), OUT out_status VARCHAR(30)) BEGIN DECLARE CONTINUE HANDLER FOR 1062 SET out_status='Duplicate Entry'; SET out_status='OK'; INSERT INTO locations (location,address1,address2,zipcode) VALUES (in_location,in_address1,in_address2,zipcode); END;