mysql 異常處理

--該文章內容經過網絡搜索組合,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

 --在異常處,先回滾以前開啓的事物,再從新開啓事物,提交日誌信息。

相關文章
相關標籤/搜索