加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql存储过程之错误处理实例细说

发布时间:2022-03-16 13:19:09 所属栏目:MySql教程 来源:互联网
导读:本文实例讲述了mysql存储过程之错误处理。分享给大家供大家参考,具体如下: 当存储过程中发生错误时,重要的是适当处理它,例如:继续或退出当前代码块的执行,并发出有意义的错误消息。其中mysql提供了一种简单的方法来定义处理从一般条件(如警告或异常)
      本文实例讲述了mysql存储过程之错误处理。分享给大家供大家参考,具体如下:
 
      当存储过程中发生错误时,重要的是适当处理它,例如:继续或退出当前代码块的执行,并发出有意义的错误消息。其中mysql提供了一种简单的方法来定义处理从一般条件(如警告或异常)到特定条件(例如特定错误代码)的处理程序。完事我们来使用DECLARE HANDLER语句来尝试声明一个处理程序,先来看语法:
 
     DECLARE action HANDLER FOR condition_value statement;
 
     上述sql中,如果条件的值与condition_value匹配,则MySQL将执行statement,并根据该操作继续或退出当前的代码块。其中,操作(action)接受以下值之一:
 
CONTINUE:继续执行封闭代码块(BEGIN ... END)。
EXIT:处理程序声明封闭代码块的执行终止。
condition_value指定一个特定条件或一类激活处理程序的条件。condition_value接受以下值之一:
 
一个MySQL错误代码。
标准SQLSTATE值或者它可以是SQLWARNING,NOTFOUND或SQLEXCEPTION条件,这是SQLSTATE值类的简写。NOTFOUND条件用于游标或SELECT INTO variable_list语句。
与MySQL错误代码或SQLSTATE值相关联的命名条件。
最重要的是,上述sql可以是一个简单的语句或由BEGIN和END关键字包围的复合语句。介绍完事之后,咱们来看几个声明处理程序的例子,首先是当程序发生错误时,将has_error变量的值设置为1并继续执行的例子:
 
以下处理程序的意思是,如果没有更多的行要提取,在光标或select into语句的情况下,将no_row_found变量的值设置为1并继续执行:
 
DECLARE CONTINUE HANDLER FOR NOT FOUND SET no_row_found = 1;
 
以下处理程序如果发生重复的键错误,则会发出MySQL错误1062。 它发出错误消息并继续执行:
 
DECLARE CONTINUE HANDLER FOR 1062
SELECT 'Error, duplicate key occurred';
 
上面这些实例可能有点抽象,咱们废话不多说,先来创建一个名为article_tags的新表,来具体操作下:
 
USE testdb;
CREATE TABLE article_tags(
  article_id INT,
  tag_id   INT,
  PRIMARY KEY(article_id,tag_id)
);
 
其中呢,article_tags表存储文章和标签之间的关系。每篇文章可能有很多标签,反之亦然。 为了简单起见,我们不会在article_tags表中创建文章(article)表和标签(tags)表以及外键。
  
然后呢,我们通过调用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);
 
我们再尝试插入一个重复的键来检查处理程序是否真的被调用:
 
CALL insert_article_tags(1,3);
 
执行上面查询语句,得到以下结果:
 
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
 
执行后会收到一条错误消息。 但是,由于我们将处理程序声明为CONTINUE处理程序,所以存储过程继续执行。

但是如果将处理程序声明中的CONTINUE更改为EXIT,那么将只会收到一条错误消息。
mysql存储过程之错误处理实例细说

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读