婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > mysql存儲過程之引發存儲過程中的錯誤條件(SIGNAL和RESIGNAL語句)實例分析

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

熱門標簽:巫師三血與酒地圖標注 萊西市地圖標注 常州網絡外呼系統開發 走過哪個省地圖標注 安徽ai電話電銷機器人有效果嗎 外呼系統電銷受騙 銷售語音電話機器人 400電話申請信用卡 在哪里申請400電話

本文實例講述了mysql引發存儲過程中的錯誤條件(SIGNAL和RESIGNAL語句)。分享給大家供大家參考,具體如下:

在mysql中,我們可以使用SIGNAL和RESIGNAL語句來引發存儲過程中的錯誤條件。

先來看,SIGNAL語句。我們通常使用SIGNAL語句在存儲的程序(例如存儲過程,存儲函數,觸發器或事件)中向調用者返回錯誤或警告條件。 SIGNAL語句提供了對返回值(如值和消息SQLSTATE)的信息的控制。來看下它的語法結構:

SIGNAL SQLSTATE | condition_name;
SET condition_information_item_name_1 = value_1,
  condition_information_item_name_1 = value_2, etc;

SIGNAL關鍵字是由DECLARE CONDITION語句聲明的SQLSTATE值或條件名稱。不過要注意的是,SIGNAL語句必須始終指定使用SQLSTATE值定義的SQLSTATE值或命名條件。完事我們如果要向調用者提供信息,就得使用SET子句,如果要使用值返回多個條件信息項名稱,則需要用逗號分隔每個名稱/值對。上述sql中,condition_information_item_name可以是MESSAGE_TEXT,MYSQL_ERRORNO,CURSOR_NAME等。咱們來看一個將訂單行項目添加到現有銷售訂單中的存儲過程,如果訂單號碼不存在,它會發出錯誤消息:

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 ;

一開始,它使用傳遞給存儲過程的輸入訂單號對訂單進行計數,完事如果訂單數不是1,它會引發SQLSTATE 45000的錯誤以及orders表中不存在訂單號的錯誤消息。其中45000是一個通用SQLSTATE值,用于說明未處理的用戶定義異常。

我們來調用存儲過程AddOrderItem(),但是傳遞不存在的訂單號,那么將收到一條錯誤消息:

CALL AddOrderItem(10,'S10_1678',1,95.7,1);

執行上面代碼,得到以下結果:

mysql> CALL AddOrderItem(10,'S10_1678',1,95.7,1);
1644 - Order No not found in orders table
mysql>

咱們再來看RESIGNAL語句。它在功能和語法方面與SIGNAL語句相似,只是有以下區別:

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

如果單獨使用RESIGNAL語句,則所有屬性與傳遞給條件處理程序的屬性相同。咱們來看一個在將發送給調用者之前更改錯誤消息的存儲過程:

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 ;

然后,我們來嘗試調用:

mysql> CALL Divide(10,0,@result);
1644 - Division by zero / Denominator cannot be zero

好啦,本次記錄就到這里了,不知道大家有沒有什么收獲。

更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL存儲過程技巧大全》、《MySQL常用函數大匯總》、《MySQL日志操作技巧大全》、《MySQL事務操作技巧匯總》及《MySQL數據庫鎖相關技巧匯總》

希望本文所述對大家MySQL數據庫計有所幫助。

您可能感興趣的文章:
  • MySQL中的if和case語句使用總結
  • mysql存儲過程之游標(DECLARE)原理與用法詳解
  • mysql存儲過程之返回多個值的方法示例
  • mysql存儲過程之創建(CREATE PROCEDURE)和調用(CALL)及變量創建(DECLARE)和賦值(SET)操作方法
  • mysql存儲過程之錯誤處理實例詳解
  • mysql存儲過程原理與使用方法詳解
  • mysql 存儲過程中變量的定義與賦值操作
  • mysql存儲過程 游標 循環使用介紹
  • MySQL存儲過程例子(包含事務,輸出參數,嵌套調用)
  • MySql存儲過程與函數詳解
  • mysql存儲過程之if語句用法實例詳解

標簽:來賓 煙臺 陽江 赤峰 河北 果洛 鞍山 黃石

巨人網絡通訊聲明:本文標題《mysql存儲過程之引發存儲過程中的錯誤條件(SIGNAL和RESIGNAL語句)實例分析》,本文關鍵詞  mysql,存儲,過程,之,引發,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《mysql存儲過程之引發存儲過程中的錯誤條件(SIGNAL和RESIGNAL語句)實例分析》相關的同類信息!
  • 本頁收集關于mysql存儲過程之引發存儲過程中的錯誤條件(SIGNAL和RESIGNAL語句)實例分析的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    中文字幕第一区第二区| 972aa.com艺术欧美| 久久色在线观看| 欧美亚洲综合一区| 成人av动漫在线| 国内成人免费视频| 六月丁香婷婷久久| 视频一区二区中文字幕| 亚洲一区二区三区在线播放| 综合激情成人伊人| 中文字幕不卡在线观看| 精品处破学生在线二十三| 91精品国产综合久久久久久久久久 | 国内精品视频666| 美腿丝袜亚洲三区| 久久99久久精品欧美| 久久99精品国产麻豆不卡| 蜜臀av一区二区| 九九国产精品视频| 国产精品一级在线| 国产精品888| 成人综合激情网| 国产·精品毛片| 成人激情黄色小说| 色婷婷亚洲精品| 欧美午夜电影在线播放| 欧美日免费三级在线| 欧美日韩第一区日日骚| 欧美日韩一本到| 欧美电影精品一区二区| 久久久美女毛片| 国产精品久久午夜| 一区二区三区中文字幕在线观看| 一区二区三区欧美| 精品久久一区二区三区| 日本一区二区三区久久久久久久久不| 日韩电影在线免费看| 在线影院国内精品| 亚洲色图制服诱惑 | 国产综合久久久久影院| 欧美一级日韩免费不卡| 视频一区二区欧美| 在线观看日产精品| 亚洲精品国产精品乱码不99| 成人激情av网| 国产亚洲欧美激情| 国产精品77777竹菊影视小说| 日韩一区二区三区四区五区六区| 香蕉成人啪国产精品视频综合网 | 国产精品网站一区| 国产福利91精品| 久久综合久久综合九色| 国内精品自线一区二区三区视频| 日韩美女啊v在线免费观看| 国产一区二区网址| 久久久精品黄色| 国产精品资源在线| 欧美激情一区二区三区在线| 国产成人免费视频| 国产精品私房写真福利视频| 波多野结衣中文字幕一区二区三区| 国产拍揄自揄精品视频麻豆| 国产成人a级片| 综合婷婷亚洲小说| 在线免费观看日本欧美| 丝袜美腿亚洲色图| www一区二区| 不卡电影一区二区三区| 一区二区三区资源| 欧美一区二区不卡视频| 久久99国内精品| 国产精品国产三级国产三级人妇| 欧美肥妇free| 国产精品久久影院| 国产成人午夜视频| 精品少妇一区二区三区免费观看| 亚洲午夜免费福利视频| 成人黄色免费短视频| 精品国产sm最大网站| 青青草精品视频| 欧美日韩精品免费| 午夜天堂影视香蕉久久| 日本韩国欧美一区| 日韩理论片一区二区| 成人国产精品视频| 国产精品女主播av| 成人av免费在线观看| 久久精品人人爽人人爽| 国产一区二区三区免费播放 | 精品中文字幕一区二区小辣椒| 欧美在线视频全部完| 亚洲精品视频一区| 日本欧美肥老太交大片| 欧美日韩一区 二区 三区 久久精品 | 国产女同互慰高潮91漫画| 一本大道久久a久久精二百| 日韩精彩视频在线观看| 国产精品久久久久影院| 欧美一区二区三区视频| 成人av资源站| 日韩电影免费在线观看网站| 国产精品久久久久aaaa樱花| 日韩一区二区三区四区五区六区| 97se亚洲国产综合自在线不卡| 老鸭窝一区二区久久精品| 亚洲免费看黄网站| 欧美经典三级视频一区二区三区| 91精品国产美女浴室洗澡无遮挡| 99综合电影在线视频| 精彩视频一区二区三区 | 欧美色精品在线视频| 精品噜噜噜噜久久久久久久久试看 | 一区二区三区四区乱视频| 久久久久久麻豆| 91精品国产免费| 欧美午夜精品久久久久久孕妇| 懂色av中文一区二区三区| 美国三级日本三级久久99| 亚洲电影中文字幕在线观看| 国产精品日韩精品欧美在线| 精品福利二区三区| 精品少妇一区二区三区日产乱码| 欧美另类高清zo欧美| 欧洲人成人精品| 91麻豆国产福利精品| 国产成人综合网站| 国产一区二区电影| 国产综合久久久久久鬼色| 日本丶国产丶欧美色综合| 亚洲成人av资源| 久久精品在线观看| 欧美四级电影在线观看| 激情小说亚洲一区| 亚洲男人天堂一区| 精品奇米国产一区二区三区| 99免费精品视频| 午夜精品久久久久久久久| 国产女主播视频一区二区| 欧美日韩精品专区| 成人小视频免费观看| 日韩主播视频在线| 国产精品免费视频网站| 欧美一区二区在线看| av男人天堂一区| 久久精品国产亚洲5555| 亚洲精品久久嫩草网站秘色| 精品理论电影在线| 欧美视频自拍偷拍| av激情成人网| 国产一区二区伦理片| 奇米影视一区二区三区小说| 久久久五月婷婷| 欧美日韩一区二区在线视频| 欧美亚洲动漫精品| 91精品国产综合久久精品图片 | 一区二区日韩av| 午夜欧美2019年伦理| 日韩电影在线看| 麻豆91在线观看| 国产精品18久久久久久久久久久久| 国产在线不卡一卡二卡三卡四卡| 国产高清不卡一区| 91网站在线播放| 欧美日韩国产天堂| 欧美成人艳星乳罩| 国产精品护士白丝一区av| 亚洲黄色性网站| 午夜精品福利一区二区蜜股av | 亚洲.国产.中文慕字在线| 日韩电影在线观看电影| 国产精品一区二区黑丝| 国产精品乱人伦| 亚洲综合色网站| 美女视频网站久久| 成人美女视频在线观看| 在线看一区二区| 欧美一级夜夜爽| 国产欧美日韩不卡| 亚洲综合一区在线| 久久精品国产免费| www.日韩精品| 日韩一区二区精品葵司在线| 国产欧美一区二区精品性色超碰| 亚洲美女在线一区| 久久精品国产亚洲a| 91偷拍与自偷拍精品| 精品国偷自产国产一区| 亚洲人成在线观看一区二区| 麻豆成人久久精品二区三区小说| eeuss鲁片一区二区三区在线看| 欧美伦理电影网| 亚洲日本欧美天堂| 中文字幕视频一区| 日韩精品资源二区在线| 久久久久久久久久看片| 国产精品嫩草影院com| 一区二区免费在线| 日韩高清在线观看| 国产偷国产偷亚洲高清人白洁| 中文文精品字幕一区二区|