springboot如何判斷mysql故障:1、拋出的異常為非運(yùn)行時(shí)異常:2、try -catch 將異常捕捉:3、需要執(zhí)行事務(wù)的方法發(fā)生了代理,代理沒(méi)有向上拋出異常:4、多線程狀態(tài)下,運(yùn)行同一段需要執(zhí)行事務(wù)的代碼。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛(ài)。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶,將通過(guò)不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名申請(qǐng)、虛擬空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、五寨網(wǎng)站維護(hù)、網(wǎng)站推廣。
mysql存儲(chǔ)過(guò)程也提供了對(duì)異常處理的功能:通過(guò)定義HANDLER來(lái)完成異常聲明的實(shí)現(xiàn)
DROP PROCEDURE IF EXISTS sp_call_jobs;
CREATE PROCEDURE sp_call_jobs()
NOT DETERMINISTIC
SQL SECURITY DEFINER
COMMENT ''
BEGIN
declare _row,_err,_count int default 0;
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION,SQLWARNING,NOT FOUND set _err=1;
while _row3 DO
START TRANSACTION;
insert into t1(cond_val)values(null);
COMMIT;
if _err=1 then
set _count=_count+1;
end if;
set _row=_row+1;
end while;
select _count;
END;
/**語(yǔ)句
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION,SQLWARNING,NOT FOUND set _err=1;
作用是當(dāng)遇到SQLEXCEPTION,SQLWARNING,NOT FOUND 錯(cuò)誤時(shí),設(shè)置_err=1并執(zhí)行CONTINUE操作,即繼續(xù)執(zhí)行后面的語(yǔ)句.
這就與c#中的try catch語(yǔ)法很像。
而且在執(zhí)行可能出錯(cuò)的語(yǔ)句的時(shí)候我們用事務(wù)語(yǔ)句:START TRANSACTION; …… COMMIT; 可以保證完整性。
**/
DECLARE處理程序的使用:
DECLARE handler_type HANDLER FOR condition_value[,...] sp_statement
其中,
handler_type的取值范圍:CONTINUE | EXIT | UNDO
condition_value的取值范圍:SQLSTATE [VALUE] sqlstate_value | condition_name | SQLWARNING | NOT FOUND | SQLEXCEPTION | mysql_error_code
這個(gè)語(yǔ)句指定每個(gè)可以處理一個(gè)或多個(gè)條件的處理程序。如果產(chǎn)生一個(gè)或多個(gè)條件,指定的語(yǔ)句被執(zhí)行。?對(duì)一個(gè)CONTINUE處理程序,當(dāng)前子程序的執(zhí)行在執(zhí)行處理程序語(yǔ)句之后繼續(xù)。對(duì)于EXIT處理程序,當(dāng)前BEGIN...END復(fù)合語(yǔ)句的執(zhí)行被終止。UNDO 處理程序類型語(yǔ)句還不被支持。
· ? SQLWARNING是對(duì)所有以01開(kāi)頭的SQLSTATE代碼的速記。
· ? ?NOT FOUND是對(duì)所有以02開(kāi)頭的SQLSTATE代碼的速記。
· ? ?SQLEXCEPTION是對(duì)所有沒(méi)有被SQLWARNING或NOT FOUND捕獲的SQLSTATE代碼的速記。
注:除了SQLSTATE值,MySQL錯(cuò)誤代碼也不被支持。
例:
[sql]?view?plain?copy?print?
delimiter?$$??
CREATE?TABLE?`_t1`?(??
`id`?int(11)?NOT?NULL?AUTO_INCREMENT,??
`val1`?varchar(20)?DEFAULT?NULL,??
`val2`?int(11)?DEFAULT?NULL,??
PRIMARY?KEY?(`id`)??
)?ENGINE=InnoDB?AUTO_INCREMENT=113?DEFAULT?CHARSET=latin1$$
[sql]?view?plain?copy?print?
DELIMITER?$$??
CREATE?DEFINER=`abandonship`@`%`?PROCEDURE?`P_TestException`()??
BEGIN??
declare?_var,_err?int?default?0;??
declare?continue?handler?for?sqlexception,?sqlwarning,?not?found?set?_err=1;??
insert?into?_t1(val1,?val2)?value(2012,'abandonship');??
if?_err=1?then??
set?_var?=?2;??
end?if;??
select?case?when?_var?=?2?then?'出錯(cuò)了'?else?_var?end;
調(diào)用該存儲(chǔ)過(guò)程將返回:出錯(cuò)了
當(dāng)前題目:mysql怎么捕獲異常 mysql存儲(chǔ)過(guò)程異常捕獲
標(biāo)題網(wǎng)址:http://chinadenli.net/article10/doddggo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、品牌網(wǎng)站制作、企業(yè)建站、全網(wǎng)營(yíng)銷推廣、小程序開(kāi)發(fā)、微信公眾號(hào)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)