您好,登錄后才能下訂單哦!
本文實(shí)例講述了mysql引發(fā)存儲過程中的錯誤條件(SIGNAL和RESIGNAL語句)。分享給大家供大家參考,具體如下:
在mysql中,我們可以使用SIGNAL和RESIGNAL語句來引發(fā)存儲過程中的錯誤條件。
先來看,SIGNAL語句。我們通常使用SIGNAL語句在存儲的程序(例如存儲過程,存儲函數(shù),觸發(fā)器或事件)中向調(diào)用者返回錯誤或警告條件。 SIGNAL語句提供了對返回值(如值和消息SQLSTATE)的信息的控制。來看下它的語法結(jié)構(gòu):
SIGNAL SQLSTATE | condition_name; SET condition_information_item_name_1 = value_1, condition_information_item_name_1 = value_2, etc;
SIGNAL關(guān)鍵字是由DECLARE CONDITION語句聲明的SQLSTATE值或條件名稱。不過要注意的是,SIGNAL語句必須始終指定使用SQLSTATE值定義的SQLSTATE值或命名條件。完事我們?nèi)绻蛘{(diào)用者提供信息,就得使用SET子句,如果要使用值返回多個條件信息項(xiàng)名稱,則需要用逗號分隔每個名稱/值對。上述sql中,condition_information_item_name可以是MESSAGE_TEXT,MYSQL_ERRORNO,CURSOR_NAME等。咱們來看一個將訂單行項(xiàng)目添加到現(xiàn)有銷售訂單中的存儲過程,如果訂單號碼不存在,它會發(fā)出錯誤消息:
DELIMITER $$ CREATE PROCEDURE AddOrderItem(in orderNo int, in productCode varchar(45), in qty int,in price double, in lineNo int ) BEGIN DECLARE C INT; SELECT COUNT(orderNumber) INTO C FROM orders WHERE orderNumber = orderNo; -- check if orderNumber exists IF(C != 1) THEN SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Order No not found in orders table'; END IF; -- more code below -- ... END $$ DELIMITER ;
一開始,它使用傳遞給存儲過程的輸入訂單號對訂單進(jìn)行計數(shù),完事如果訂單數(shù)不是1,它會引發(fā)SQLSTATE 45000的錯誤以及orders表中不存在訂單號的錯誤消息。其中45000是一個通用SQLSTATE值,用于說明未處理的用戶定義異常。
我們來調(diào)用存儲過程AddOrderItem(),但是傳遞不存在的訂單號,那么將收到一條錯誤消息:
CALL AddOrderItem(10,'S10_1678',1,95.7,1);
執(zhí)行上面代碼,得到以下結(jié)果:
mysql> CALL AddOrderItem(10,'S10_1678',1,95.7,1); 1644 - Order No not found in orders table mysql>
咱們再來看RESIGNAL語句。它在功能和語法方面與SIGNAL語句相似,只是有以下區(qū)別:
如果單獨(dú)使用RESIGNAL語句,則所有屬性與傳遞給條件處理程序的屬性相同。咱們來看一個在將發(fā)送給調(diào)用者之前更改錯誤消息的存儲過程:
DELIMITER $$ CREATE PROCEDURE Divide(IN numerator INT, IN denominator INT, OUT result double) BEGIN DECLARE division_by_zero CONDITION FOR SQLSTATE '22012'; DECLARE CONTINUE HANDLER FOR division_by_zero RESIGNAL SET MESSAGE_TEXT = 'Division by zero / Denominator cannot be zero'; -- IF denominator = 0 THEN SIGNAL division_by_zero; ELSE SET result := numerator / denominator; END IF; END $$ DELIMITER ;
然后,我們來嘗試調(diào)用:
mysql> CALL Divide(10,0,@result); 1644 - Division by zero / Denominator cannot be zero
好啦,本次記錄就到這里了,不知道大家有沒有什么收獲。
更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL存儲過程技巧大全》、《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》及《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總》
希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。