一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - mysql存儲過程中的異常處理解析

mysql存儲過程中的異常處理解析

2020-06-23 15:13cookiehu Mysql

這篇文章主要為大家詳細介紹了mysql存儲過程中的異常處理,感興趣的小伙伴們可以參考一下

定義異常捕獲類型及處理方法: 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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 

這里面需要注意幾點: 

a、condition_value [,condition_value],這個的話說明可以包括多種情況(方括弧表示可選的),也就是一個handler可以定義成針對多種情況進行相應的 操作;另外condition_value可以包括的值有上面列出來的6種:

1、mysql_error_code,這個表示mysql的錯誤代碼,錯誤代碼是一個數字,完成是由mysql自己定義的,這個值可以參考mysql數據庫錯誤代碼及信息。

2、SQLSTATE [VALUE] sqlstate_value,這個同錯誤代碼類似形成一一對應的關系,它是一個5個字符組成的字符串,關鍵的地方是它從ANSI SQL和ODBC這些標準中引用過來的,因此更加標準化,而不像上面的error_code完全是mysql自己定義給自己用的,這個和第一個類似也可以 參考mysql數據庫錯誤代碼及信息。

3、condtion_name,這個是條件名稱,它使用DECLARE...CONDITION語句來定義,這個后面我們會介紹如何定義自己的condition_name。

4、SQLWARNING,表示SQLTATE中的字符串以‘01'起始的那些錯誤,比如Error: 1311 SQLSTATE: 01000 (ER_SP_UNINIT_VAR)

5、NOT FOUND,表示SQLTATE中的字符串以‘02'起始的那些錯誤,比如Error: 1329 SQLSTATE: 02000 (ER_SP_FETCH_NO_DATA)

6、SQLEXCEPTION,表示SQLSTATE中的字符串不是以'00'、'01'、'02' 起始的那些錯誤,這里'00'起始的SQLSTATE其實表示的是成功執行而不是錯誤,另外兩個就是上面的4和5的兩種情況。 

上面的6種情況其實可以分為兩類:

一類就是比較明確的處理,就是對指定的錯誤情況進行處理,包括1、2、3這三種方式;

另一類是對對應類型的錯誤的 處理,就是對某一群錯誤的處理,包括4、5、6這三種方式。這個是介紹了condition_value。另外還要注意的一個內容是MySQL在默認情況 下(也就是我們沒有定義處理錯誤的方法-handler)自己的錯誤處理機制:

1、對于SQLWARNING和NOT FOUND的處理方法就是無視錯誤繼續執行,所以在游標的例子里面如果我們沒有對repeat的條件判斷的那個值做個no_more_products=1的handler來處理,那么循環就會一直下去。

2、對于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的可讀性太差,所以引入了命名條件: 

語法: 

?
1
2
3
4
5
DECLARE condition_name CONDITION FOR condition_value
 
condition_value:
  SQLSTATE [VALUE] sqlstate_value
 | mysql_error_code 

使用:

?
1
2
3
4
5
6
# 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;
  

示例: 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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;

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲精品国精品久久99热 | 国产精品免费视频能看 | 国模娜娜一区二区三区 | 四虎最新永久免费视频 | 91精品国产色综合久久 | 欧美日韩一区二区综合在线视频 | 欧乱色国产精品兔费视频 | 91好色 | 爱情岛论坛亚洲自拍 | 天天干天天操天天碰 | 国产精品久久久久久久人人看 | 天天色视频| 国产一级片免费观看 | 国产盗摄女厕美女嘘嘘 | 爆操| 日本破处 | 国产在线98福利播放视频免费 | 99精品免费在线观看 | 欧美亚洲另类在线观看 | 好姑娘在线观看完整版免费 | 国产91在线精品狼人 | 肉蒲在线观看 | 亚洲九九爱 | 日本护士xxxx视频 | 91久久偷偷做嫩草影院免费看 | 男生同性啪视频在线观看 | 欧美亚洲桃花综合 | 日本色播| 四虎永久成人免费 | 精品久久伦理中文字幕 | 禁忌h1v1怀孕 | 国产一区二区三区四区波多野结衣 | 精品免费tv久久久久久久 | bdsm中国精品调教 | 人配人种视频xxxx | 青青草成人在线 | a一级黄| 日韩黄色影视 | 成人免费在线视频 | 7个黑人玩北条麻妃 | 人成午夜免费大片在线观看 |