广告
返回顶部
首页 > 资讯 > 数据库 >MySQL存储过程的“异常处理”
  • 320
分享到

MySQL存储过程的“异常处理”

2024-04-02 19:04:59 320人浏览 薄情痞子
摘要

Q:何为异常?A:程序在执行过程中有可能出错,运行时错误叫做异常。默认情况下,当存储过程运行出错时,过程会立即终止,并打印系统错误消息。 实验环境:Mysql> use 

Q:何为异常?

A:程序在执行过程中有可能出错,运行时错误叫做异常。

默认情况下,当存储过程运行出错时,过程会立即终止,并打印系统错误消息。

 

实验环境:

MySQL存储过程的“异常处理”

Mysql> use TENNIS
Reading table infORMation for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> show tables;+-------------------+
| Tables_in_TENNIS  |
+-------------------+
| COMMITTEE_MEMBERS |
| MATCHES           |
| PENALTIES         |
| PLAYERS           |
| TEAMS             |
+-------------------+5 rows in set (0.00 sec)

MySQL存储过程的“异常处理”

因为前面的实验多数用此数据库,库表结构就不再赘述了。

 

例:创建过程,插入一个重复的2号球队

MySQL存储过程的“异常处理”

mysql> delimiter $$
mysql> create procedure duplicate_teams(    ->   out p_processed smallint)    -> begin    ->   set p_processed=1;    ->   insert into TEAMS values(2,27,'third');    ->   set p_processed=2;    -> end $$
mysql> delimiter ;
mysql> call duplicate_teams(@processed);ERROR 1062 (23000): Duplicate entry '2' for key 'PRIMARY'mysql> select @processed;+------------+
| @processed |
+------------+
| NULL       |
+------------+

MySQL存储过程的“异常处理”

解析:客户端调用存储过程,运行出错,打印错误信息,过程被终止,没有输出。

 

一、定义异常处理:

DECLARE ... HANDLER语句:

  通过条件的定义和处理,可以在定义过程中,针对可能遇到的问题,做出相应的处理步骤。(也就是定义一个异常处理程序,指定当过程某条语句出错时,相应的采取什么操作)

MySQL存储过程的“异常处理”

DECLARE handler_action HANDLER
    FOR condition_value [, condition_value] ...
    statement

handler_action:
    CONTINUE    | EXIT

condition_value:
    mysql_error_code    | SQLSTATE [VALUE] sqlstate_value    | condition_name    | SQLWARNING    | NOT FOUND    | SQLEXCEPTION

MySQL存储过程的“异常处理”

注意:declare……handler语句必须出现在变量或条件声明的后面。

  当某个错误(condition_value)发生时--->执行指定的语句(statement--记录错误信息),执行完之后再决定如何操作(handler_action)。

  1、handler_action

    continue:继续执行当前的程序(接着执行出错的SQL的下一条语句);

    exit:当前程序终止(退出当前declare所在的begin end);

  目前还不支持undo功能。

  2、statement

    可以是单条语句或复合语句。

  3、condition_value指明handler被何种条件触发;如果条件被触发,却没有handler被声明用于处理该条件,程序的进行将取决于条件类型。

【top】 

 

二、单个异常处理程序

  在输出参数中包含出错消息的SQLSTATE码。

例1:创建过程,插入一个重复的2号球队;continue

MySQL存储过程的“异常处理”

mysql> DELIMITER $$
mysql> CREATE  PROCEDURE small_mistake1( 
    ->   OUT error VARCHAR(5))  
    -> BEGIN    ->   DECLARE CONTINUE HANDLER FOR SQLSTATE '23000' 
    ->   SET error = '23000';    #用来记录错误发生时的一些信息    ->          
    ->   select error;    ->   SET error = '00000';    ->   select error;    ->    INSERT INTO TEAMS VALUES(2,27,'third');  #会出错的语句    ->    SET error = '23001';     
    -> END$$
mysql> DELIMITER ;
mysql> call small_mistake1(@a);+-------+
| error |
+-------+
| NULL  |
+-------+

+-------+
| error |
+-------+
| 00000 |
+-------+mysql> select @a;+-------+
| @a    |
+-------+
| 23001 |
+-------+

MySQL存储过程的“异常处理”

实验示例解析:

  begin end块里,定义declare……handler语句用来捕获错误(待命ing),select、set、select顺序执行,insert语句出错,SQLSTATE码23000,捕获,进行异常处理(赋值记录),结束后会继续执行出错的insert语句的下一条语句……

 

例2:创建过程,插入一个重复的2号球队;exit

MySQL存储过程的“异常处理”

mysql> DELIMITER $$
mysql> CREATE  PROCEDURE small_mistake2( 
    ->   OUT error VARCHAR(5))  
    -> BEGIN    ->   DECLARE EXIT HANDLER FOR SQLSTATE '23000' 
    ->   SET error = '23000';    ->                 
    ->   select error;    ->   SET error = '00000';    ->   select error;    ->   INSERT INTO TEAMS VALUES(2,27,'third');    ->   SET error = '23001';     
    -> END$$
mysql> DELIMITER ;
mysql> call small_mistake2(@a);+-------+
| error |
+-------+
| NULL  |
+-------+

+-------+
| error |
+-------+
| 00000 |
+-------+mysql> select @a;+-------+
| @a    |
+-------+
| 23000 |
+-------+

MySQL存储过程的“异常处理”

与例1唯一不同的是:handler_action选择的是exit,表明在异常处理结束后不会继续执行错误语句后面的语句,直接退出begin end语句块。

 【top】

 

三、多个异常处理程序

  可以在一个过程中定义多个异常处理程序,针对不同的错误进行不同的处理。

例1:

MySQL存储过程的“异常处理”

mysql> INSERT INTO TEAMS VALUES(2,27,'third',5);
ERROR 1136 (21S01): Column count doesn't match value count at row 1mysql> DELIMITER $$
mysql> CREATE  PROCEDURE small_mistake3( 
    ->   OUT error VARCHAR(5))  
    -> BEGIN    ->   DECLARE CONTINUE HANDLER FOR SQLSTATE '23000'  
    ->   SET error = '23000'; 
    ->   
    ->   DECLARE CONTINUE HANDLER FOR SQLSTATE '21S01' 
    ->   SET error = '21S01';    ->     
    ->   INSERT INTO TEAMS VALUES(2,27,'third',5);  #错误语句   
    -> END$$
mysql> DELIMITER ;
mysql> call small_mistake3(@error);
mysql> select @error;+--------+
| @error |
+--------+
| 21S01  |
+--------+

MySQL存储过程的“异常处理”

解析:

  如果SQLSTATE码是23000,异常处理执行SET error = '23000';

  如果SQLSTATE码是21S01,异常处理执行SET error = '21S01';

当然,异常处理,可以是自定义,一般都是上述方式的错误信息记录。

 

示例3中的异常处理程序也可以使用错误编号

例如:

DECLARE CONTINUE HANDLER FOR 1062 
        SET error = '23000';     

DECLARE CONTINUE HANDLER FOR 1136 
        SET error = '21S01';

 

关于错误编号和SQLSTATE码:

  每个MySQL错误都有一个唯一的数字错误编号(mysql_error_code),每个错误又对应一个5字符的SQLSTATE码(ANSI SQL 采用)。

SQLSTATE码对应的处理程序:

  1、SQLWARNING处理程序:以‘01’开头的所有sqlstate码与之对应;

  2、NOT FOUND处理程序:以‘02’开头的所有sqlstate码与之对应;

  3、SQLEXCEPTION处理程序:不以‘01’或‘02’开头的所有sqlstate码,也就是所有未被SQLWARNING或NOT FOUND捕获的SQLSTATE(常遇到的MySQL错误就是非‘01’、‘02’开头的)

注意:‘01’、‘02’开头和‘1’、‘2’开头是有区别的,是不一样的错误sqlsate码。

 

当不想为每个错误都定义一个处理程序时,可以使用3个处理程序

  e.g:DECLARE CONTINUE HANDLER FOR SQLWARNING,NOT FOUND,SQLEXCEPTION  

MySQL存储过程的“异常处理”

mysql> DELIMITER $$
mysql> CREATE  PROCEDURE small_mistake4( 
    ->   OUT error VARCHAR(5))  
    -> BEGIN    ->   DECLARE CONTINUE HANDLER FOR SQLWARNING,NOT FOUND,SQLEXCEPTION  
    ->   SET error = 'xxxxx';  
    ->          
    ->   INSERT INTO teams VALUES(2,27,'third');   
    -> END$$
mysql> DELIMITER ;
mysql> call small_mistake4(@a);
mysql> select @a;+-------+
| @a    |
+-------+
| xxxxx |
+-------+

MySQL存储过程的“异常处理”

 

如果是在定义处理程序时,想忽略某一个条件

e.g:DECLARE CONTINUE HANDLER FOR SQLWARNING BEGIN END;

也就是说,当遇到SQLWARNING的问题时,进行的异常处理是begin end块,因为里面什么都没有,就类同于直接忽略。

 【top】

 

四、异常处理的命名

  为了提高可读性,可以给某个sqlstate代码或mysql错误代码一个名字,并且在后面的异常处理程序中使用这个名字。

DECLARE condition_name CONDITION FOR condition_value
condition_value:
    mysql_error_code   |SQLSTATE [VALUE] sqlstate_value

1、未命名的基本格式:

BEGIN
  DECLARE CONTINUE HANDLER FOR 1051
    -- body of handler
END;

 

2、有命名的基本格式:

BEGIN
  DECLARE no_such_table CONDITION FOR 1051;
  DECLARE CONTINUE HANDLER FOR no_such_table    -- body of handler
END;

MySQL存储过程的“异常处理”

mysql> DELIMITER $$
mysql> CREATE  PROCEDURE small_mistake5( 
    ->   OUT error VARCHAR(5))  
    -> BEGIN    ->   DECLARE non_unique CONDITION FOR SQLSTATE '23000';  
    ->   DECLARE CONTINUE HANDLER FOR non_unique    ->   begin 
    ->     SET error = '23000';    ->     select error;    ->   end;    ->
    ->   INSERT INTO TEAMS VALUES(2,27,'third');  #会出错语句  
    -> END$$
mysql> DELIMITER ;
mysql> call small_mistake5(@error);+-------+
| error |
+-------+
| 23000 |
+-------+

MySQL存储过程的“异常处理”

 【top】

 

五、异常传播

  在嵌套块的情况下,内部块中发生异常了,首先由本块的异常处理程序来处理,如果本块没有处理,则由外部块的异常处理程序来处理。

MySQL存储过程的“异常处理”

mysql> DELIMITER $$
mysql> CREATE  PROCEDURE small_mistake6()  
    -> BEGIN    
    ->   DECLARE CONTINUE HANDLER FOR SQLSTATE '23000' 
    ->   SET @processed = 100;  
    ->    ->   BEGIN      
    ->     DECLARE CONTINUE HANDLER FOR SQLSTATE '21000' 
    ->     SET @processed = 200;    
    ->     INSERT INTO TEAMS VALUES(2,27,'third');   
    ->     set @test=123321;  
    ->    END;    -> END$$
mysql> DELIMITER ;
mysql> call small_mistake6;
mysql> select @processed,@test;+------------+--------+
| @processed | @test |
+------------+--------+
| 300 | 123321 |
+------------+--------+


您可能感兴趣的文档:

--结束END--

本文标题: MySQL存储过程的“异常处理”

本文链接: https://www.lsjlt.com/news/37415.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL存储过程的“异常处理”
    Q:何为异常?A:程序在执行过程中有可能出错,运行时错误叫做异常。默认情况下,当存储过程运行出错时,过程会立即终止,并打印系统错误消息。 实验环境:mysql> use ...
    99+
    2022-10-18
  • MySQL中的存储过程异常处理
    目录1. condition2.handler3.diagnostics area在使用mysql存储过程时,其中的代码可能会出现运行错误从而导致异常,此时需要将存储过程中产生的异常捕获并打印出来 需要知道的概念: co...
    99+
    2022-09-26
  • MySQL存储过程异常处理的方法是什么
    MySQL存储过程可以通过以下方法进行异常处理: 使用DECLARE语句声明一个异常变量,然后使用HANDLER语句来处理异常。例...
    99+
    2023-10-25
    MySQL
  • MySQL存储过程中出现异常如何处理
    下面一起来了解下MySQL存储过程中出现异常如何处理,相信大家看完肯定会受益匪浅,文字在精不在多,希望MySQL存储过程中出现异常如何处理这篇短内容是你想要的。      &n...
    99+
    2022-10-18
  • mysql存储过程异常如何解决
    这篇文章主要介绍“mysql存储过程异常如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mysql存储过程异常如何解决”文章能帮助大家解决问题。 ...
    99+
    2023-05-25
    mysql
  • MySQL中存储过程定义条件和异常处理的示例分析
    小编给大家分享一下MySQL中存储过程定义条件和异常处理的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! 查看调用存储过程时的报错代码mysql>...
    99+
    2022-10-18
  • MySQL 存储过程空结果集错误Error 1329 No data 的异常处理
    在MySQL的存储过程中,当查询到空结果集时会产生下面报错 Error 1329 No data - zero rows fetched, selected, or processed 解决方法: 在存储...
    99+
    2022-10-18
  • mysql 存储过程执行异常,参数不是出参
    执行存储过程时,出现如下错误,一般都是因为调用用户没有对应操作权限导致. Parameter number 1 is not an OUT parameter 检查用户对应权限 show grants...
    99+
    2022-10-18
  • oracle存储过程异常如何捕捉
    在Oracle中,可以使用异常处理来捕获存储过程中的异常。在存储过程中,可以使用以下语句来捕获异常并进行处理:sqlDECLARE ...
    99+
    2023-10-25
    oracle
  • mysql的存储过程
    什么是存储过程 一组可编程的函数,是为了完成特定功能的SQL语句集 经编译创建并保存在数据库中,用户可通过指定存储过程的名字并给定参数(需要时)来调用执行。 存储过程就是具有名字的一段代码,用来完成一个特定的功能。 创建的存储过...
    99+
    2015-04-21
    mysql的存储过程
  • 如何处理MySQL存储过程的权限问题
    这篇文章主要介绍如何处理MySQL存储过程的权限问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! MySQL的存储过程,没错,看起来好生僻的使...
    99+
    2022-10-18
  • MySQL存储过程中的sql_mode问题怎么处理
    这篇文章主要介绍MySQL存储过程中的sql_mode问题怎么处理,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在my.cnf中设置了sql_mode='STRICT_TRA...
    99+
    2022-10-18
  • SqlServer中存储过程如何捕获异常
    这期内容当中小编将会给大家带来有关SqlServer中存储过程如何捕获异常,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。  SqlServer中的存储过程怎么捕获异常  ...
    99+
    2022-10-18
  • sqlserver中存储过程事务处理常见问题
    在编写SQL Server 事务相关的存储过程代码时,经常看到下面这样的写法: begin tran update statement 1 ... update statement 2 ... delete statement ...
    99+
    2020-12-03
    sqlserver中存储过程事务处理常见问题
  • MySQL存储过程怎么理解
    MySQL存储过程是一段预先编译好的SQL代码块,可以被多次调用和执行。它可以接受参数、执行SQL语句、执行控制流程和返回结果。存储过程的主要目的是将一系列的SQL操作组合在一起,并在数据库服务器上进行执行。这样可以提高数据库的性能,减...
    99+
    2023-08-11
    MySQL
  • mysql存储过程之错误处理实例详解
    本文实例讲述了mysql存储过程之错误处理。分享给大家供大家参考,具体如下: 当存储过程中发生错误时,重要的是适当处理它,例如:继续或退出当前代码块的执行,并发出有意义的错误消息。其中mysql提供了一种简...
    99+
    2022-10-18
  • oracle存储过程打印异常怎么解决
    在Oracle存储过程中,可以使用`EXCEPTION`语句块来处理异常并打印错误信息。以下是一个示例:sqlCREATE OR R...
    99+
    2023-10-25
    oracle
  • MySQL存储过程理解和作用
    存储过程是存储在数据库目录中的一段声明性SQL语句。方便其他应用程序可以调用存储过程。 储存器的作用 1, 通常存储过程有助于提高应用程序的性能。 2,存储过程有助于减少应用程序和数据库服务器之间的流...
    99+
    2022-10-18
  • MYSQL中怎么管理存储过程
    今天就跟大家聊聊有关MYSQL中怎么管理存储过程,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。查看存储过程函数名:存储过程:(注意字段name,ty...
    99+
    2022-10-18
  • mysql的存储过程介绍
    什么是mysql存储过程?存储程序是被存储在服务器中的组合SQL语句,经编译创建并保存在数据库中,用户可通过存储过程的名字调用执行。存储过程核心思想就是数据库SQL语言层面的封装与重用性。使用存储过程可以较...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作