我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL 5.5新增SIGNAL异常处理怎么用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL 5.5新增SIGNAL异常处理怎么用

这篇文章主要介绍MySQL 5.5新增SIGNAL异常处理怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

MySQL 5.5新增SIGNAL异常处理
 
MySQL 从 5.0 开始支持存储过程,到现在最新版本5.5 已经好几个年头了。 虽然MYSQL的异常处理不是很完善,但是处理大多数的应用还是足够了。
异常处理的语句有如下几种:
1. DECLARE ... CONDITION.
2. DECLARE ... HANDLER.
3. RESIGNAL.
4. SIGNAL.
 
第一种,名为条件声明。
DECLARE condition_name CONDITION FOR condition_value
 
这里condition_name 为标准的变量命名, condition_value 为SQLSTATE 值 或者 MySQL 自身的ERROR CODE.
单独的condition 语句不能直接运行。 只能作为第二种的一部分。
  www.2cto.com  
第二种, 名为条件处理。
第一种声明好了,接下来自然要做相应的处理。
DECLARE handler_action HANDLER
    FOR condition_value [, condition_value] ...
    statement
 
handler_action:
    CONTINUE
  | EXIT
  | UNDO
 
condition_value:
    mysql_error_code
  | SQLSTATE [VALUE] sqlstate_value
  | condition_name
  | SQLWARNING
  | NOT FOUND
  | SQLEXCEPTION
 
handler_action 代表处理的动作,目前有效的有两种, 继续和直接退出。
condition_value 有好几种,其中包括前面条件声明里的SQLSTATE, MYSQL EEROR CODE, condition_name 以及范围混淆的其他两种
SQLWARNING,SQLEXCEPTION. NOT FOUND表示任何不存在的WARNING或者ERROR。
 
第三种, 代表伪装系统的错误信息以及代码,刷新当前警告缓冲区域。
RESIGNAL [condition_value]
    [SET signal_information_item
    [, signal_information_item] ...]
 
condition_value:
    SQLSTATE [VALUE] sqlstate_value
  | condition_name
 
signal_information_item:
    condition_information_item_name = simple_value_specification
 
condition_information_item_name:
    CLASS_ORIGIN
  | SUBCLASS_ORIGIN
  | MESSAGE_TEXT
  | MYSQL_ERRNO
  | CONSTRAINT_CATALOG
  | CONSTRAINT_SCHEMA
  | CONSTRAINT_NAME
  | CATALOG_NAME
  | SCHEMA_NAME
  | TABLE_NAME
  | COLUMN_NAME
  | CURSOR_NAME
 
特别注意的是可以伪装的具体东西很多,包括错误代码(MYSQL自身的东东),错误内容,错误的名,表名,列名等等。
 
第四种,SIGNAL和RESIGNAL差别不大,我们记住signal 不能单独运行,resignal可以单独运行。
SIGNAL condition_value
    [SET signal_information_item
    [, signal_information_item] ...]
 
condition_value:
    SQLSTATE [VALUE] sqlstate_value
  | condition_name
 
signal_information_item:
    condition_information_item_name = simple_value_specification
 
condition_information_item_name:
    CLASS_ORIGIN
  | SUBCLASS_ORIGIN
  | MESSAGE_TEXT
  | MYSQL_ERRNO
  | CONSTRAINT_CATALOG
  | CONSTRAINT_SCHEMA
  | CONSTRAINT_NAME
  | CATALOG_NAME
  | SCHEMA_NAME
  | TABLE_NAME
  | COLUMN_NAME
  | CURSOR_NAME
 
我们现在给几个例子。
 
不用RESIGNAL/SIGNAL。
[sql] 
DELIMITER $$  
  
USE `t_girl`$$  
  
DROP PROCEDURE IF EXISTS `sp_signal1`$$  
  
CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_signal1`(  
    IN f_id INT  
    )  
BEGIN  
      DECLARE con1 TINYINT DEFAULT 0;  
      DECLARE con1 CONDITION FOR SQLSTATE '23000';  
      DECLARE CONTINUE HANDLER FOR con1  
      BEGIN  
        SELECT 'Error Code : 22\r\nDuplicated!';  
      END;  
      INSERT INTO user_info VALUES (f_id);  
    END$$  
  
DELIMITER ;  
 
CALL sp_signal1(12);
 
query result
 
result
Error Code : 22
Duplicated!
 
用RESIGNAL/SIGNAL 重刷当前错误诊断区域。
 
[sql] 
DELIMITER $$  
  
    www.2cto.com  
USE `t_girl`$$  
  
  
DROP PROCEDURE IF EXISTS `sp_signal1`$$  
  
  
CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_signal1`(  
    IN f_id INT  
    )  
BEGIN  
      DECLARE con1 TINYINT DEFAULT 0;  
      DECLARE con1 CONDITION FOR SQLSTATE '23000';  
      DECLARE CONTINUE HANDLER FOR con1  
      BEGIN  
        resignal SET schema_name = 'action',   
             table_name = 'action_tb',   
             message_text = 'Duplicated!',  
                     _errno = 22;  
 
      END;  
      INSERT INTO user_info VALUES (f_id);  
    END$$  
  
DELIMITER ;  
 
CALL sp_signal1(12);
  www.2cto.com  
Query : call sp_signal1(12)
Error Code : 22
Duplicated!
Execution Time : 00:00:00:000
Transfer Time  : 00:00:00:000
Total Time     : 00:00:00:000
 
 

以上是“MySQL 5.5新增SIGNAL异常处理怎么用”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL 5.5新增SIGNAL异常处理怎么用

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

下载Word文档

猜你喜欢

mysql innodb异常怎么处理

本文小编为大家详细介绍“mysql innodb异常怎么处理”,内容详细,步骤清晰,细节处理妥当,希望这篇“mysql innodb异常怎么处理”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、回退重新装mysq
2023-06-27

mysql异常捕获怎么处理

mysql异常处理包括两种方法:1. try-catch 块;2. 使用 mysqli_errno 和 mysqli_error 函数。异常处理步骤通常包括:1. 捕获异常;2. 检查错误代码;3. 采取适当行动,如终止脚本、重试查询或通知
mysql异常捕获怎么处理
2024-05-30

rpc调用异常怎么处理

处理 RPC 调用异常的方法取决于具体的情况和所使用的 RPC 框架。以下是一些常见的处理方法:异常捕获和处理:在发起 RPC 调用的代码块中使用 try-catch 块来捕获异常,并根据异常类型进行相应的处理。可以根据具体的异常信息进行日
2023-10-23

Java异常处理try catch怎么用

这篇文章将为大家详细讲解有关Java异常处理try catch怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。我们编译运行程序出错的时候,编译器就会抛出异常。抛出异常要比终止程序灵活许多,这是因为Ja
2023-06-21

VB.NET结构化异常处理怎么用

这篇文章主要介绍VB.NET结构化异常处理怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!概述 相较于VB语言来说,VB.NET引入了许多特色。其中最值得注意的变化就是引入了VB.NET结构化异常处理。虽然VB.
2023-06-17

怎么在Python中利用Selenium处理异常

这篇文章将为大家详细讲解有关怎么在Python中利用Selenium处理异常,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Python的优点有哪些1、简单易用,与C/C++、Java、C#
2023-06-14

怎么在java中使用finally处理异常

怎么在java中使用finally处理异常?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Java可以用来干什么Java主要应用于:1. web开发;2. Android开发
2023-06-14

怎么使用whoops接管tp6的异常处理

小编给大家分享一下怎么使用whoops接管tp6的异常处理,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!春节期间熟悉了TP6, 也写了一个TP6的博客程序,但系统
2023-06-07

怎么利用Proxy更优雅地处理异常

这篇文章给大家分享的是有关怎么利用Proxy更优雅地处理异常的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。代码不会全部按照我们的预期运行,可能会有意料之外的情况,为了保证程序的健壮性,要进行异常处理。比如一个对象
2023-06-29

SpringMVC基于配置的异常处理器怎么用

这篇文章主要介绍了SpringMVC基于配置的异常处理器怎么用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SpringMVC基于配置的异常处理器怎么用文章都会有所收获,下面我们一起来看看吧。一、基于配置的异常
2023-06-30

JAVA中异常处理使用不当该怎么办

JAVA中异常处理使用不当该怎么办,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。★空的 catch 语句块  犯这种错误的人比较少,一般发生在刚学会 Java
2023-06-02

怎么在python中使用except对异常进行处理

本篇文章为大家展示了怎么在python中使用except对异常进行处理,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。python有哪些常用库python常用的库:1.requesuts;2.scra
2023-06-14

C#中怎么使用try-catch-finally结构处理异常

在C#中,可以使用try-catch-finally结构来处理异常。try块中包含可能会引发异常的代码,catch块用于捕获并处理异常,finally块则用于执行无论是否发生异常都需要执行的代码。下面是一个简单的示例,演示了如何使用try
C#中怎么使用try-catch-finally结构处理异常
2024-03-06

使用SpringMVC怎么实现一个全局异常处理器

本篇文章给大家分享的是有关使用SpringMVC怎么实现一个全局异常处理器,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。首先,创建一个自定义的异常类/** * @Title:
2023-05-31

编程热搜

目录