欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql存儲過程之引發(fā)存儲過程中的錯誤條件(SIGNAL和RESIGNAL語句)實例分析

 更新時間:2019年12月23日 11:13:52   作者:luyaran  
這篇文章主要介紹了mysql存儲過程之引發(fā)存儲過程中的錯誤條件(SIGNAL和RESIGNAL語句),結(jié)合實例形式分析了mysql使用SIGNAL和RESIGNAL語句來引發(fā)存儲過程中的錯誤條件相關(guān)操作技巧與注意事項,需要的朋友可以參考下

本文實例講述了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子句,如果要使用值返回多個條件信息項名稱,則需要用逗號分隔每個名稱/值對。上述sql中,condition_information_item_name可以是MESSAGE_TEXT,MYSQL_ERRORNO,CURSOR_NAME等。咱們來看一個將訂單行項目添加到現(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 ;

一開始,它使用傳遞給存儲過程的輸入訂單號對訂單進行計數(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ū)別:

  • 必須在錯誤或警告處理程序中使用RESIGNAL語句,否則您將收到一條錯誤消息,指出“RESIGNAL when handler is not active”。 請注意,您可以在存儲過程中的任何位置使用SIGNAL語句。
  • 可以省略RESIGNAL語句的所有屬性,甚至可以省略SQLSTATE值。

如果單獨使用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事務操作技巧匯總》及《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總

希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。

相關(guān)文章

  • oracle轉(zhuǎn)mysql語句轉(zhuǎn)換實例代碼

    oracle轉(zhuǎn)mysql語句轉(zhuǎn)換實例代碼

    最近由于公司業(yè)務上需要,需要將原項目的數(shù)據(jù)庫由oracle轉(zhuǎn)換成mysql,下面這篇文章主要給大家介紹了關(guān)于oracle轉(zhuǎn)mysql語句轉(zhuǎn)換的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-06-06
  • 關(guān)于MySQL的時間進位問題淺析

    關(guān)于MySQL的時間進位問題淺析

    這篇文章主要給大家介紹了關(guān)于MySQL的時間進位問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用MySQL具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-12-12
  • MySQL插入時間差八小時問題的解決方法

    MySQL插入時間差八小時問題的解決方法

    這篇文章主要給大家介紹了關(guān)于MySQL插入時間差八小時問題的解決方法,文中通過示例代碼介紹的非常詳細,對大家學習或者使用MySQL具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-12-12
  • MySQL全量備份的實現(xiàn)

    MySQL全量備份的實現(xiàn)

    全量備份是MySQL數(shù)據(jù)庫備份的常見方式,本文主要介紹了MySQL全量備份的實現(xiàn),全量備份和增量備份是 MySQL 數(shù)據(jù)庫備份的兩種常見方式
    2024-04-04
  • MySQL timestamp自動更新時間分享

    MySQL timestamp自動更新時間分享

    在mysql中timestamp數(shù)據(jù)類型是一個比較特殊的數(shù)據(jù)類型,他可以自動在你不使用程序更新情況下只要你更新了記錄timestamp會自動更新時間
    2013-06-06
  • MySQL8.0.23版本的root密碼重置最優(yōu)解法

    MySQL8.0.23版本的root密碼重置最優(yōu)解法

    這篇文章主要介紹了MySQL8.0.23版本的root密碼重置最優(yōu)解法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • MySQL樂觀鎖和悲觀鎖具體實現(xiàn)

    MySQL樂觀鎖和悲觀鎖具體實現(xiàn)

    這篇文章主要介紹了MySQL樂觀鎖和悲觀鎖具體實現(xiàn),文章圍繞主題展開詳細的內(nèi)容戒殺,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • mysql獲取當前日期年月的兩種實現(xiàn)方式

    mysql獲取當前日期年月的兩種實現(xiàn)方式

    這篇文章主要介紹了mysql獲取當前日期年月的兩種實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • MySQL CHECK約束(5.7和8.0)的使用

    MySQL CHECK約束(5.7和8.0)的使用

    CHECK約束用于確保數(shù)據(jù)表中的某列或多列的數(shù)據(jù)符合特定的條件,本文主要介紹了MySQL CHECK約束(5.7和8.0)的使用,具有一定的參考價值,感興趣的可以了解一下
    2024-08-08
  • 關(guān)于mysql中string和number的轉(zhuǎn)換問題

    關(guān)于mysql中string和number的轉(zhuǎn)換問題

    這篇文章主要介紹了關(guān)于mysql中string和number的轉(zhuǎn)換問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06

最新評論