--該文章內容經過網絡搜索組合,mysql
mysql 異常,能夠自定義異常,再應用。也可以使用系統默認的異常,捕獲應用。sql
1、異常定義:網絡
DECLARE condition_name CONDITION FOR [condition_type];日誌
condition_name參數表示異常的名稱;code
condition_type參數異常類型字符串
condition_type由SQLSTATE [VALUE] sqlstate_value|mysql_error_code組成:get
sqlstate_value和mysql_error_code均可以表示MySQL的錯誤;it
sqlstate_value爲長度爲5的字符串類型的錯誤代碼;mysql_error_code爲數值類型錯誤代碼;io
舉例:table
定義「ERROR 1148(42000)」錯誤,名稱爲command_not_allowed。能夠有如下兩種方法:
//方法一:使用sqlstate_value
DECLARE command_not_allowed CONDITION FOR SQLSTATE '42000';
//方法二:使用mysql_error_code
DECLARE command_not_allowed CONDITION FOR 1148;
2、異常處理
DECLARE handler_type HANDLER FOR condition_value [,...] sp_statement
handler_type: CONTINUE|EXIT|UNDO
handler_type爲錯誤處理方式,參數爲3個值之一;
CONTINUE表示遇到錯誤不處理,繼續執行;
EXIT表示遇到錯誤時立刻退出;
UNDO表示遇到錯誤後撤回以前的操做,MySQL暫不支持回滾操做;
condition_value: SQLSTATE [VALUE] sqlstate_value| condition_name|SQLWARNING|NOT FOUND|SQLEXCEPTION|mysql_error_code
condition_value表示錯誤類型;SQLSTATE [VALUE] sqlstate_value爲包含5個字符的字符串錯誤值;
condition_name表示DECLARE CONDITION定義的錯誤條件名稱;
SQLWARNING匹配全部以01開頭的SQLSTATE錯誤代碼;
NOT FOUND匹配全部以02開頭的SQLSTATE錯誤代碼;
SQLEXCEPTION匹配全部沒有被SQLWARNING或NOT FOUND捕獲的SQLSTATE錯誤代碼;
mysql_error_code匹配數值類型錯誤代碼;
舉例:
//方法一:捕獲sqlstate_value異常
//這種方法是捕獲sqlstate_value值。若是遇到sqlstate_value值爲"42S02",執行CONTINUE操做,並輸出"NO_SUCH_TABLE"信息
DECLARE CONTINUE HANDLER FOR SQLSTATE '42S02' SET @info='NO_SUCH_TABLE';
//方法二:捕獲mysql_error_code異常
//這種方法是捕獲mysql_error_code值。若是遇到mysql_error_code值爲1146,執行CONTINUE操做,並輸出"NO_SUCH_TABLE"信息;
DECLARE CONTINUE HANDLER FOR 1146 SET @info='NO_SUCH_TABLE';
//方法三:先定義條件,而後捕獲異常
DECLARE no_such_table CONDITION FOR 1146;
DECLARE CONTINUE HANDLER FOR NO_SUCH_TABLE SET @info='NO_SUCH_TABLE';
//方法四:使用SQLWARNING捕獲異常
DECLARE EXIT HANDLER FOR SQLWARNING SET @info='ERROR';
//方法五:使用NOT FOUND捕獲異常
DECLARE EXIT HANDLER FOR NOT FOUND SET @info='NO_SUCH_TABLE';
//方法六:使用SQLEXCEPTION捕獲異常
DECLARE EXIT HANDLER FOR SQLEXCEPTION SET @info='ERROR';
3.實例
1.
CREATE PROCEDURE P_TEST_EXCEP()
BEGIN
DECLARE EXIT HANDLER for SQLEXCEPTION INSERT into TEST_LOG(id) VALUES(1);
START TRANSACTION;
INSERT into TEST(id) VALUES(11);--主鍵不衝突
INSERT into TEST(id) VALUES(1);--主鍵衝突
INSERT into TEST(id) VALUES(111);--主鍵不衝突
commit;
END
--實際發現,此時日誌表也被回滾了。
二、
CREATE PROCEDURE P_TEST_EXCEP()
BEGIN
declare t_error int default 0;
DECLARE CONTINUE HANDLER for SQLEXCEPTION SET t_error=1;
START TRANSACTION;
INSERT into TEST(id) VALUES(11);--主鍵不衝突
INSERT into TEST(id) VALUES(1);--主鍵衝突
INSERT into TEST(id) VALUES(111);--主鍵不衝突
if t_error=1 THEN
ROLLBACK;
ELSE
commit;
end if;
END
3.
CREATE PROCEDURE P_TEST_EXCEP()
BEGIN
DECLARE EXIT HANDLER for SQLEXCEPTION begin ROLLBACK ; START TRANSACTION;INSERT into TEST_LOG(id) VALUES(1); commit; end;
START TRANSACTION;
INSERT into TEST(id) VALUES(11);--主鍵不衝突
INSERT into TEST(id) VALUES(1);--主鍵衝突
INSERT into TEST(id) VALUES(111);--主鍵不衝突
commit;
END
--在異常處,先回滾以前開啓的事物,再從新開啓事物,提交日誌信息。