mysql存儲過程中的異常處理解析
定義異常捕獲類型及處理方法:
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可以定義成針對多種情況進(jìn)行相應(yīng)的 操作;另外condition_value可以包括的值有上面列出來的6種:
1、mysql_error_code,這個表示mysql的錯誤代碼,錯誤代碼是一個數(shù)字,完成是由mysql自己定義的,這個值可以參考mysql數(shù)據(jù)庫錯誤代碼及信息。
2、SQLSTATE [VALUE] sqlstate_value,這個同錯誤代碼類似形成一一對應(yīng)的關(guān)系,它是一個5個字符組成的字符串,關(guān)鍵的地方是它從ANSI SQL和ODBC這些標(biāo)準(zhǔn)中引用過來的,因此更加標(biāo)準(zhǔn)化,而不像上面的error_code完全是mysql自己定義給自己用的,這個和第一個類似也可以 參考mysql數(shù)據(jù)庫錯誤代碼及信息。
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其實表示的是成功執(zhí)行而不是錯誤,另外兩個就是上面的4和5的兩種情況。
上面的6種情況其實可以分為兩類:
一類就是比較明確的處理,就是對指定的錯誤情況進(jìn)行處理,包括1、2、3這三種方式;
另一類是對對應(yīng)類型的錯誤的 處理,就是對某一群錯誤的處理,包括4、5、6這三種方式。這個是介紹了condition_value。另外還要注意的一個內(nèi)容是MySQL在默認(rèn)情況 下(也就是我們沒有定義處理錯誤的方法-handler)自己的錯誤處理機(jī)制:
1、對于SQLWARNING和NOT FOUND的處理方法就是無視錯誤繼續(xù)執(zhí)行,所以在游標(biāo)的例子里面如果我們沒有對repeat的條件判斷的那個值做個no_more_products=1的handler來處理,那么循環(huán)就會一直下去。
2、對于SQLEXCEPTION的話,其默認(rèn)的處理方法是在出現(xiàn)錯誤的地方就終止掉了。
b、statement,這個比較簡單就是當(dāng)出現(xiàn)某種條件/錯誤時,我們要執(zhí)行的語句,可以是簡單的如 SET var = value這樣的簡單的語句,也可以是復(fù)雜的多行的語句,多行的話可以使用BEGIN ..... END這里把語句包括在里面(這個好比delphi里面的情況,注意到我們的存儲過程也是多行的,所以也要BEGIN .... END)。
c、handler_action,這個表示當(dāng)執(zhí)行完上面的statement后,希望執(zhí)行怎樣的動作,這里包括CONTINUE、EXIT、UNDO, 表示繼續(xù)、退出、撤銷(暫時不支持)。這邊就是兩種動作,其實這兩種動作在上面也說過了,CONTINUE就是一個是SQLWARNING和NOT FOUND的默認(rèn)處理方法,而EXIT就是SQLEXCEPTION的默認(rèn)處理方法。
另:
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;
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
解析windows下使用命令的方式安裝mysql5.7的方法
這篇文章主要介紹了windows下使用命令的方式安裝mysql5.7的方法,本文圖文并茂給大家介紹的非常詳細(xì),需要的朋友可以參考下2017-01-01
將MySQL help contents的內(nèi)容有層次的輸出方法推薦
如何將MySQL help contents的內(nèi)容有層次的輸出呢?下面小編就為大家?guī)硪黄獙ySQL help contents的內(nèi)容有層次的輸出方法推薦。小編覺得挺不錯的,現(xiàn)在分享給大家,給大家一個參考。一起跟隨小編過來看看吧2016-03-03
簡析mysql字符集導(dǎo)致恢復(fù)數(shù)據(jù)庫報錯問題
這篇文章主要介紹了簡析mysql字符集導(dǎo)致恢復(fù)數(shù)據(jù)庫報錯問題,具有一定參考價值,需要的朋友可以了解。2017-10-10
MySql 8.0.16版本安裝提示已經(jīng)不使用“UTF8B3”而是使用“UTF8B4”問題
這篇文章主要介紹了MySql 8.0.16版本安裝提示已經(jīng)不使用“UTF8B3”而是使用“UTF8B4”問題 ,需要的朋友可以參考下2019-07-07
centos7.4系統(tǒng)中yum源安裝mysql 5.6
本文給大家介紹的是如何在centos7.4系統(tǒng)中通過yum源安裝MySQL 5.6數(shù)據(jù)庫,CentOS7默認(rèn)數(shù)據(jù)庫是mariadb, 但是 好多用的都是mysql ,但是CentOS7的yum源中默認(rèn)好像是沒有mysql的,今天我們就來看看具體如何操作2018-09-09

