mysql存储过程之错误处理实例详解

  

本文实例讲述了mysql存储过程之错误处理。分享给大家供大家参考,具体如下:

  

当存储过程中发生错误时,重要的是适当处理它,例如:继续或退出当前代码块的执行,并发出有意义的错误消息。其中mysql提供了一种简单的方法来定义处理从一般条件(如警告或异常)到特定条件(例如特定错误代码)的处理程序。完事我们来使用声明处理程序语句来尝试声明一个处理程序,先来看语法:

        声明condition_value语句的操作处理程序;      之前      

上述sql中,如果条件的值与condition_value匹配,则MySQL将执行声明,并根据该操作继续或退出当前的代码块。其中,操作(行动)接受以下值之一:

  
      <李>继续:继续执行封闭代码块(开始…李结束)。   <李>退出:处理程序声明封闭代码块的执行终止。   
  

condition_value指定一个特定条件或一类激活处理程序的条件.condition_value接受以下值之一:

  
      <李>一个MySQL错误代码。   <李>标准SQLSTATE值或者它可以是SQLWARNING, NOTFOUND或SQLEXCEPTION条件,这是SQLSTATE值类的简写.NOTFOUND条件用于游标或SELECT INTO variable_list语句。   <李>与MySQL错误代码或SQLSTATE值相关联的命名条件。   
  

最重要的是,上述sql可以是一个简单的语句或由开始和结束关键字包围的复合语句。介绍完事之后,咱们来看几个声明处理程序的例子,首先是当程序发生错误时,将has_error变量的值设置为1并继续执行的例子:

        声明继续处理SQLEXCEPTION设置has_error=1;      之前      

再来看当发生错误时,回滚上一个操作,发出错误消息,并退出当前代码块。如果在存储过程的开始结束块中声明它,则会立即终止存储过程:

        宣布退出处理SQLEXCEPTION异常   开始   回滚;   选择“一个错误已经发生,操作回滚和存储过程终止的;   结束;      之前      

以下处理程序的意思是,如果没有更多的行要提取,在光标或select into语句的情况下,将no_row_found变量的值设置为1并继续执行:

        声明继续处理程序没有找到设置no_row_found=1;      之前      

以下处理程序如果发生重复的键错误,则会发出MySQL错误1062年。它发出错误消息并继续执行:

        1062年宣布继续处理程序   选择“发生错误,重复键”;      之前      

上面这些实例可能有点抽象,咱们废话不多说,先来创建一个名为article_tags的新表,来具体操作下:

        使用testdb;   创建表article_tags (   article_id INT,   tag_id INT,   主键(article_id tag_id)   );      之前      

其中呢,article_tags表存储文章和标签之间的关系。每篇文章可能有很多标签,反之亦然。为了简单起见,我们不会在article_tags表中创建文章(条)表和标签(标签)表以及外键。

  

完事呢,我们来创建一个存储过程,将文章的id和标签的id插入到article_tags表中:

        使用testdb;   分隔符$ $   创建过程insert_article_tags(在tag_id article_id INT, INT)   开始   1062年宣布继续处理程序   选择CONCAT(重复键(article_id,,, tag_id)发现的)味精;   ——向article_tags插入新记录   插入article_tags (article_id tag_id)   值(article_id tag_id);   ——返回标签条数   从article_tags SELECT COUNT (*);   结束$ $   分隔符;      之前      

然后呢,我们通过调用insert_article_tags存储过程,为文章ID为1添加标签ID: 1、2和3,如下所示:

        调用insert_article_tags (1,1);   调用insert_article_tags (1、2);   调用insert_article_tags (1、3);      之前      

我们再尝试插入一个重复的键来检查处理程序是否真的被调用:

        调用insert_article_tags (1、3);      之前      

执行上面查询语句,得到以下结果:

        mysql>调用insert_article_tags (1、3);   +----------------------------+   |味精|   +----------------------------+   | |复制钥匙(1、3)发现   +----------------------------+   1行组   + - - - - - - - - - - - +   | | COUNT (*)   + - - - - - - - - - - - +   | 3 |   + - - - - - - - - - - - +   1行组   查询好,0行受影响      

mysql存储过程之错误处理实例详解