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

主頁 > 知識庫 > mysql存儲過程之錯誤處理實例詳解

mysql存儲過程之錯誤處理實例詳解

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

本文實例講述了mysql存儲過程之錯誤處理。分享給大家供大家參考,具體如下:

當存儲過程中發(fā)生錯誤時,重要的是適當處理它,例如:繼續(xù)或退出當前代碼塊的執(zhí)行,并發(fā)出有意義的錯誤消息。其中mysql提供了一種簡單的方法來定義處理從一般條件(如警告或異常)到特定條件(例如特定錯誤代碼)的處理程序。完事我們來使用DECLARE HANDLER語句來嘗試聲明一個處理程序,先來看語法:

DECLARE action HANDLER FOR condition_value statement;

上述sql中,如果條件的值與condition_value匹配,則MySQL將執(zhí)行statement,并根據(jù)該操作繼續(xù)或退出當前的代碼塊。其中,操作(action)接受以下值之一:

  • CONTINUE:繼續(xù)執(zhí)行封閉代碼塊(BEGIN ... END)。
  • EXIT:處理程序聲明封閉代碼塊的執(zhí)行終止。

condition_value指定一個特定條件或一類激活處理程序的條件。condition_value接受以下值之一:

  • 一個MySQL錯誤代碼。
  • 標準SQLSTATE值或者它可以是SQLWARNING,NOTFOUND或SQLEXCEPTION條件,這是SQLSTATE值類的簡寫。NOTFOUND條件用于游標或SELECT INTO variable_list語句。
  • 與MySQL錯誤代碼或SQLSTATE值相關聯(lián)的命名條件。

最重要的是,上述sql可以是一個簡單的語句或由BEGIN和END關鍵字包圍的復合語句。介紹完事之后,咱們來看幾個聲明處理程序的例子,首先是當程序發(fā)生錯誤時,將has_error變量的值設置為1并繼續(xù)執(zhí)行的例子:

DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET has_error = 1;

再來看當發(fā)生錯誤時,回滾上一個操作,發(fā)出錯誤消息,并退出當前代碼塊。 如果在存儲過程的BEGIN END塊中聲明它,則會立即終止存儲過程:

DECLARE EXIT HANDLER FOR SQLEXCEPTION
BEGIN
ROLLBACK;
SELECT 'An error has occurred, operation rollbacked and the stored procedure was terminated';
END;

以下處理程序的意思是,如果沒有更多的行要提取,在光標或select into語句的情況下,將no_row_found變量的值設置為1并繼續(xù)執(zhí)行:

DECLARE CONTINUE HANDLER FOR NOT FOUND SET no_row_found = 1;

以下處理程序如果發(fā)生重復的鍵錯誤,則會發(fā)出MySQL錯誤1062。 它發(fā)出錯誤消息并繼續(xù)執(zhí)行:

DECLARE CONTINUE HANDLER FOR 1062
SELECT 'Error, duplicate key occurred';

上面這些實例可能有點抽象,咱們廢話不多說,先來創(chuàng)建一個名為article_tags的新表,來具體操作下:

USE testdb;
CREATE TABLE article_tags(
  article_id INT,
  tag_id   INT,
  PRIMARY KEY(article_id,tag_id)
);

其中呢,article_tags表存儲文章和標簽之間的關系。每篇文章可能有很多標簽,反之亦然。 為了簡單起見,我們不會在article_tags表中創(chuàng)建文章(article)表和標簽(tags)表以及外鍵。

完事呢,我們來創(chuàng)建一個存儲過程,將文章的id和標簽的id插入到article_tags表中:

USE testdb;
DELIMITER $$
CREATE PROCEDURE insert_article_tags(IN article_id INT, IN tag_id INT)
BEGIN
 DECLARE CONTINUE HANDLER FOR 1062
 SELECT CONCAT('duplicate keys (',article_id,',',tag_id,') found') AS msg;
 -- insert a new record into article_tags
 INSERT INTO article_tags(article_id,tag_id)
 VALUES(article_id,tag_id);
 -- return tag count for the article
 SELECT COUNT(*) FROM article_tags;
END$$
DELIMITER ;

然后呢,我們通過調(diào)用insert_article_tags存儲過程,為文章ID為1添加標簽ID:1,2和3,如下所示:

CALL insert_article_tags(1,1);
CALL insert_article_tags(1,2);
CALL insert_article_tags(1,3);

我們再嘗試插入一個重復的鍵來檢查處理程序是否真的被調(diào)用:

CALL insert_article_tags(1,3);

執(zhí)行上面查詢語句,得到以下結果:

mysql> CALL insert_article_tags(1,3);
+----------------------------+
| msg            |
+----------------------------+
| duplicate keys (1,3) found |
+----------------------------+
1 row in set
+----------+
| COUNT(*) |
+----------+
|    3 |
+----------+
1 row in set
Query OK, 0 rows affected

執(zhí)行后會收到一條錯誤消息。 但是,由于我們將處理程序聲明為CONTINUE處理程序,所以存儲過程繼續(xù)執(zhí)行。因此,最后獲得了文章的標簽計數(shù)值為:3。來看個圖:

但是如果將處理程序聲明中的CONTINUE更改為EXIT,那么將只會收到一條錯誤消息。如下查詢語句:

DELIMITER $$
CREATE PROCEDURE insert_article_tags_exit(IN article_id INT, IN tag_id INT)
BEGIN
 DECLARE EXIT HANDLER FOR SQLEXCEPTION 
 SELECT 'SQLException invoked';
 DECLARE EXIT HANDLER FOR 1062 
    SELECT 'MySQL error code 1062 invoked';
 DECLARE EXIT HANDLER FOR SQLSTATE '23000'
 SELECT 'SQLSTATE 23000 invoked';
 -- insert a new record into article_tags
 INSERT INTO article_tags(article_id,tag_id)
  VALUES(article_id,tag_id);
 -- return tag count for the article
 SELECT COUNT(*) FROM article_tags;
END $$
DELIMITER ;

執(zhí)行上面查詢語句,得到以下結果:

mysql> CALL insert_article_tags_exit(1,3);
+-------------------------------+
| MySQL error code 1062 invoked |
+-------------------------------+
| MySQL error code 1062 invoked |
+-------------------------------+
1 row in set
Query OK, 0 rows affected

來看個圖感受下:

如果我們使用多個處理程序來處理錯誤,MySQL將調(diào)用最特定的處理程序來處理錯誤。這就涉及到優(yōu)先級的問題了,我們來具體看下。

我們知道錯誤總是映射到一個MySQL錯誤代碼,因為在MySQL中它是最具體的。 SQLSTATE可以映射到許多MySQL錯誤代碼,因此它不太具體。 SQLEXCPETION或SQLWARNING是SQLSTATES類型值的縮寫,因此它是最通用的。假設在insert_article_tags_3存儲過程中聲明三個處理程序,如下所示:

DELIMITER $$
CREATE PROCEDURE insert_article_tags_3(IN article_id INT, IN tag_id INT)
BEGIN
 DECLARE EXIT HANDLER FOR 1062 SELECT 'Duplicate keys error encountered';
 DECLARE EXIT HANDLER FOR SQLEXCEPTION SELECT 'SQLException encountered';
 DECLARE EXIT HANDLER FOR SQLSTATE '23000' SELECT 'SQLSTATE 23000';
 -- insert a new record into article_tags
 INSERT INTO article_tags(article_id,tag_id)
 VALUES(article_id,tag_id);
 -- return tag count for the article
 SELECT COUNT(*) FROM article_tags;
END $$
DELIMITER ;

然后我們嘗試通過調(diào)用存儲過程將重復的鍵插入到article_tags表中:

CALL insert_article_tags_3(1,3);

如下,可以看到MySQL錯誤代碼處理程序被調(diào)用:

mysql> CALL insert_article_tags_3(1,3);
+----------------------------------+
| Duplicate keys error encountered |
+----------------------------------+
| Duplicate keys error encountered |
+----------------------------------+
1 row in set
Query OK, 0 rows affected

完事之后,咱們再來看下使用命名錯誤條件。從錯誤處理程序聲明開始,如下:

DECLARE EXIT HANDLER FOR 1051 SELECT 'Please create table abc first';
SELECT * FROM abc;

1051號是什么意思? 想象一下,你有一個大的存儲過程代碼使用了好多類似這樣的數(shù)字; 這將成為維護代碼的噩夢。幸運的是,MySQL為我們提供了聲明一個命名錯誤條件的DECLARE CONDITION語句,它與條件相關聯(lián)。DECLARE CONDITION語句的語法如下:

DECLARE condition_name CONDITION FOR condition_value;

condition_value可以是MySQL錯誤代碼,例如:1015或SQLSTATE值。 condition_value由condition_name表示。聲明后,可以參考condition_name,而不是參考condition_value。所以可以重寫上面的代碼如下:

DECLARE table_not_found CONDITION for 1051;
DECLARE EXIT HANDLER FOR table_not_found SELECT 'Please create table abc first';
SELECT * FROM abc;

這段代碼比以前的代碼顯然更可讀,不過我們要注意,條件聲明必須出現(xiàn)在處理程序或游標聲明之前。

好啦,這次就到這里了。

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

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

您可能感興趣的文章:
  • MySQL中的if和case語句使用總結
  • mysql存儲過程之游標(DECLARE)原理與用法詳解
  • mysql存儲過程之返回多個值的方法示例
  • mysql存儲過程之創(chuàng)建(CREATE PROCEDURE)和調(diào)用(CALL)及變量創(chuàng)建(DECLARE)和賦值(SET)操作方法
  • mysql存儲過程之引發(fā)存儲過程中的錯誤條件(SIGNAL和RESIGNAL語句)實例分析
  • mysql存儲過程原理與使用方法詳解
  • mysql 存儲過程中變量的定義與賦值操作
  • mysql存儲過程 游標 循環(huán)使用介紹
  • MySQL存儲過程例子(包含事務,輸出參數(shù),嵌套調(diào)用)
  • MySql存儲過程與函數(shù)詳解
  • mysql存儲過程之if語句用法實例詳解

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

巨人網(wǎng)絡通訊聲明:本文標題《mysql存儲過程之錯誤處理實例詳解》,本文關鍵詞  mysql,存儲,過程,之,錯誤,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《mysql存儲過程之錯誤處理實例詳解》相關的同類信息!
  • 本頁收集關于mysql存儲過程之錯誤處理實例詳解的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    久久久久高清精品| 天天射综合影视| 亚洲国产精品麻豆| 日韩一区二区三区在线视频| 国产精品国产a| 欧美一区二区三区日韩| 国产精品亚洲视频| 亚洲码国产岛国毛片在线| 精品国精品国产| 国产一区二区三区最好精华液| 中文字幕不卡一区| 精品少妇一区二区三区免费观看| 成人高清视频在线| 日本成人在线电影网| 亚洲黄色免费网站| 欧美mv和日韩mv国产网站| 欧美在线你懂得| 91麻豆123| 国产福利一区在线| 日本vs亚洲vs韩国一区三区二区| 亚洲午夜影视影院在线观看| 国产精品五月天| 欧美乱熟臀69xxxxxx| 欧美天堂一区二区三区| 国产+成+人+亚洲欧洲自线| 亚洲欧美一区二区三区国产精品| 国产精品色哟哟网站| 精品国产乱码久久久久久浪潮 | 一区二区三区高清不卡| 日韩一二三四区| 91视频在线观看| 国产成人久久精品77777最新版本| 精品夜夜嗨av一区二区三区| 午夜精品123| 亚洲精选免费视频| 日日噜噜夜夜狠狠视频欧美人| 亚洲免费大片在线观看| 国产女人18水真多18精品一级做| 亚洲一区二区欧美日韩| 亚洲区小说区图片区qvod| 亚洲欧洲一区二区三区| 亚洲午夜久久久| 亚洲国产乱码最新视频| 国产精品美女久久久久aⅴ国产馆| 中文幕一区二区三区久久蜜桃| 精品少妇一区二区三区视频免付费 | 日韩欧美在线网站| 欧美日韩国产欧美日美国产精品| 在线观看不卡视频| 日本韩国视频一区二区| 欧洲一区二区av| 日韩女优毛片在线| 岛国一区二区三区| 91视频国产观看| 日韩色视频在线观看| 91精品国产麻豆| 26uuu欧美| 亚洲一区二区三区视频在线| 午夜天堂影视香蕉久久| 日本v片在线高清不卡在线观看| 国产一区二区三区四区五区美女 | 久久99精品久久久久| 亚洲狠狠爱一区二区三区| 国内精品写真在线观看| av激情亚洲男人天堂| 91久久精品国产91性色tv| 欧美另类高清zo欧美| 亚洲视频狠狠干| 日本美女一区二区| 在线一区二区三区四区| 日韩一区二区三区观看| 国产人妖乱国产精品人妖| 日韩黄色免费电影| 国产一区 二区| 国产精品中文欧美| 欧美一卡二卡在线| 国产精品久久久久影视| 麻豆91精品视频| 99riav久久精品riav| 欧美精品乱人伦久久久久久| 精品国产在天天线2019| 久久精品欧美一区二区三区麻豆| 亚洲人成亚洲人成在线观看图片 | 欧美高清在线一区| ㊣最新国产の精品bt伙计久久| 亚洲国产欧美一区二区三区丁香婷| 国产一区二区成人久久免费影院| 日本高清不卡在线观看| 欧美一区二区三区在线观看视频| 一区二区三区四区高清精品免费观看| 蜜臀精品一区二区三区在线观看| 成人av在线观| 欧美国产精品专区| 蜜臀av一区二区在线观看| 91国模大尺度私拍在线视频| 亚洲人成在线观看一区二区| 国产一区二区三区久久久| 欧美情侣在线播放| 免费观看久久久4p| 欧美视频一区在线| 国产精品久久久久国产精品日日| 福利一区在线观看| 日韩一区二区中文字幕| 亚洲愉拍自拍另类高清精品| 色呦呦一区二区三区| 久久久精品免费观看| 毛片av一区二区| 欧美成人r级一区二区三区| 亚洲一区二区三区在线播放| 成人国产免费视频| 亚洲精品午夜久久久| 99免费精品视频| 欧美一区二区国产| 激情六月婷婷久久| 欧美成人aa大片| 亚洲成人免费av| av网站免费线看精品| 国产精品毛片久久久久久| 国产精品99久| 精品视频全国免费看| 国产精品成人免费在线| 丁香六月久久综合狠狠色| 一区二区三区成人| 色综合中文字幕国产 | 精品一区二区久久| av影院午夜一区| 中文字幕一区二区三区色视频| 视频一区国产视频| 日韩精品一级中文字幕精品视频免费观看| 午夜精品免费在线| 欧美专区日韩专区| 亚洲.国产.中文慕字在线| 欧美日韩久久一区二区| 制服丝袜中文字幕亚洲| 亚洲视频一区在线| 色婷婷久久久亚洲一区二区三区| 久久久亚洲高清| 国产综合一区二区| 不卡的av网站| 精品国产一区二区三区久久影院 | 成人av电影在线| 午夜国产精品影院在线观看| 日韩电影在线观看电影| 蜜乳av一区二区| 26uuu国产一区二区三区| 成人免费小视频| 欧美日韩综合色| 午夜精品久久久久久久久久久 | 婷婷国产v国产偷v亚洲高清| 日韩欧美成人激情| 亚洲成人中文在线| 欧美一级午夜免费电影| 国产一区二区在线电影| 日本亚洲三级在线| 欧美高清精品3d| 婷婷丁香激情综合| 亚洲免费观看在线观看| 99在线视频精品| 国产精品99久久久久| 欧美大片在线观看一区二区| 久久婷婷一区二区三区| www.色精品| 国产九九视频一区二区三区| 亚洲综合色丁香婷婷六月图片| 国产欧美日韩亚州综合| 精品视频在线看| 欧美性色综合网| 91丝袜国产在线播放| 成人污污视频在线观看| 国产一区二区视频在线播放| 韩国午夜理伦三级不卡影院| 亚洲国产精品久久一线不卡| 欧美精品一区二区精品网| av亚洲精华国产精华精华| jlzzjlzz国产精品久久| 91亚洲精品久久久蜜桃| 国精产品一区一区三区mba桃花| 国产精品亲子伦对白| 日韩欧美国产成人一区二区| 91麻豆精品国产91久久久资源速度| 国产午夜精品理论片a级大结局 | 欧美性极品少妇| 色综合久久中文综合久久97| 国产成人av福利| 国产一区二区三区四| 成人黄色av网站在线| 不卡一区二区中文字幕| voyeur盗摄精品| 91在线小视频| 日韩欧美国产综合| 欧美高清在线精品一区| 中文字幕色av一区二区三区| 国产精品久久久久四虎| 亚洲免费观看高清| 五月婷婷欧美视频| 美女视频黄频大全不卡视频在线播放| 亚洲成在线观看| 91一区二区三区在线观看| 欧美国产日韩在线观看| 亚洲综合在线免费观看|