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

mysql存儲過程之錯(cuò)誤處理實(shí)例詳解

 更新時(shí)間:2019年12月20日 09:00:12   作者:luyaran  
這篇文章主要介紹了mysql存儲過程之錯(cuò)誤處理,結(jié)合實(shí)例形式詳細(xì)分析了mysql存儲過程錯(cuò)誤處理相關(guān)原理、操作技巧與注意事項(xiàng),需要的朋友可以參考下

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

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

DECLARE action HANDLER FOR condition_value statement;

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

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

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

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

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

DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET has_error = 1;

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

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

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

DECLARE CONTINUE HANDLER FOR NOT FOUND SET no_row_found = 1;

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

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

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

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

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

完事呢,我們來創(chuàng)建一個(gè)存儲過程,將文章的id和標(biāo)簽的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添加標(biāo)簽ID:1,2和3,如下所示:

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

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

CALL insert_article_tags(1,3);

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

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í)行后會(huì)收到一條錯(cuò)誤消息。 但是,由于我們將處理程序聲明為CONTINUE處理程序,所以存儲過程繼續(xù)執(zhí)行。因此,最后獲得了文章的標(biāo)簽計(jì)數(shù)值為:3。來看個(gè)圖:

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

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í)行上面查詢語句,得到以下結(jié)果:

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

來看個(gè)圖感受下:

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

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

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)用存儲過程將重復(fù)的鍵插入到article_tags表中:

CALL insert_article_tags_3(1,3);

如下,可以看到MySQL錯(cuò)誤代碼處理程序被調(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

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

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

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

DECLARE condition_name CONDITION FOR condition_value;

condition_value可以是MySQL錯(cuò)誤代碼,例如: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)在處理程序或游標(biāo)聲明之前。

好啦,這次就到這里了。

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

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

相關(guān)文章

  • MySQL復(fù)制之GTID復(fù)制的具體使用

    MySQL復(fù)制之GTID復(fù)制的具體使用

    從MySQL 5.6.5開始新增了一種基于GTID的復(fù)制方式,本文主要介紹了MySQL復(fù)制之GTID復(fù)制的具體使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • mysql8中如何設(shè)置sql-mode

    mysql8中如何設(shè)置sql-mode

    這篇文章主要介紹了mysql8中如何設(shè)置sql-mode問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • 深入聊聊MySQL中各種對象的大小長度限制

    深入聊聊MySQL中各種對象的大小長度限制

    在使用mysql的過程中總會(huì)遇到或大或小的問題,這篇文章主要給大家介紹了關(guān)于MySQL中各種對象的大小長度限制的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用mysql具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-12-12
  • Mysql sql慢查詢監(jiān)控腳本代碼實(shí)例

    Mysql sql慢查詢監(jiān)控腳本代碼實(shí)例

    這篇文章主要介紹了Mysql sql慢查詢監(jiān)控腳本代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • MySQL快速復(fù)制數(shù)據(jù)庫數(shù)據(jù)表的方法

    MySQL快速復(fù)制數(shù)據(jù)庫數(shù)據(jù)表的方法

    有些時(shí)候,我們?yōu)榱丝焖俅罱ㄒ粋€(gè)測試環(huán)境,或者說是克隆一個(gè)網(wǎng)站,需要復(fù)制已經(jīng)存在的mysql數(shù)據(jù)庫。下面小編給大家介紹mysql快速復(fù)制數(shù)據(jù)庫數(shù)據(jù)表的方法,小伙伴們跟著小編一起學(xué)習(xí)吧
    2015-10-10
  • MySQL復(fù)制表的三種方式(小結(jié))

    MySQL復(fù)制表的三種方式(小結(jié))

    這篇文章主要介紹了MySQL復(fù)制表的三種方式(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • mysql 5.5.56免安裝版配置方法

    mysql 5.5.56免安裝版配置方法

    這篇文章主要介紹了mysql 5.5.56免安裝版配置方法,本文通過文字實(shí)例代碼相結(jié)合的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-06-06
  • 如何添加一個(gè)mysql用戶并給予權(quán)限詳解

    如何添加一個(gè)mysql用戶并給予權(quán)限詳解

    在很多時(shí)候我們并不會(huì)直接利用mysql的root用戶進(jìn)行項(xiàng)目的開發(fā),一般我們都會(huì)創(chuàng)建一個(gè)具有部分權(quán)限的用戶,下面這篇文章主要給大家介紹了關(guān)于如何添加一個(gè)mysql用戶并給予權(quán)限的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • MyEclipse連接MySQL數(shù)據(jù)庫報(bào)錯(cuò)解決辦法

    MyEclipse連接MySQL數(shù)據(jù)庫報(bào)錯(cuò)解決辦法

    我們現(xiàn)在一般網(wǎng)站都是利用的MySQL數(shù)據(jù)庫搭建網(wǎng)站的,但是在網(wǎng)上看到很多網(wǎng)友吐槽數(shù)據(jù)庫連接不上的問題,現(xiàn)在我就結(jié)合相關(guān)資料向提出一些我個(gè)人的見解,希望對大家解決問題有幫助
    2014-01-01
  • mysql 一次向表中插入多條數(shù)據(jù)實(shí)例講解

    mysql 一次向表中插入多條數(shù)據(jù)實(shí)例講解

    這篇文章主要介紹了mysql 一次向表中插入多條數(shù)據(jù)實(shí)例講解的相關(guān)資料,需要的朋友可以參考下
    2016-10-10

最新評論