mysql存储过程运行跟踪_mysql存储过程中的错误怎样跟踪

mysql存储过程中的错误怎样跟踪

关注:170  答案:2  mip版

解决时间 2021-01-16 13:34

e6cb1a03ad541b3098697807b7bf1798.png

提问者落叶、牵绊着思念

2021-01-16 08:30

mysql存储过程中的错误怎样跟踪

最佳答案

e6cb1a03ad541b3098697807b7bf1798.png

二级知识专家用命换你心

2021-01-16 09:39

DECLARE处理程序的使用:

DECLARE handler_type HANDLER FOR condition_value[,...] sp_statement

其中,

handler_type的取值范围:CONTINUE | EXIT | UNDO

condition_value的取值范围:SQLSTATE [VALUE] sqlstate_value | condition_name | SQLWARNING | NOT FOUND | SQLEXCEPTION | mysql_error_code

这个语句指定每个可以处理一个或多个条件的处理程序。如果产生一个或多个条件,指定的语句被执行。 对一个CONTINUE处理程序,当前子程序的执行在执行处理程序语句之后继续。对于EXIT处理程序,当前BEGIN...END复合语句的执行被终止。UNDO 处理程序类型语句还不被支持。

· SQLWARNING是对所有以01开头的SQLSTATE代码的速记。

· NOT FOUND是对所有以02开头的SQLSTATE代码的速记。

· SQLEXCEPTION是对所有没有被SQLWARNING或NOT FOUND捕获的SQLSTATE代码的速记。

注:除了SQLSTATE值,MySQL错误代码也不被支持。

例:

delimiter $$

CREATE TABLE `_t1` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`val1` varchar(20) DEFAULT NULL,

`val2` int(11) DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=113 DEFAULT CHARSET=latin1$$

DELIMITER $$

CREATE DEFINER=`abandonship`@`%` PROCEDURE `P_TestException`()

BEGIN

declare _var,_err int default 0;

declare continue handler for sqlexception, sqlwarning, not found set _err=1;

insert into _t1(val1, val2) value(2012,'abandonship');

if _err=1 then

set _var = 2;

end if;

select case when _var = 2 then '出错了' else _var end;

END

调用该存储过程将返回:出错了

全部回答

e6cb1a03ad541b3098697807b7bf1798.png

1楼癡情菂尐豬豬

2021-01-16 09:59

declare是用来定义变量和常用处理、声明之类的关键字。在mysql存储过程出现之前declare是一块鸡肋,大家常用declare来定义局部变量,我习惯性的还是使用set来定义变量(虽然是全局的,但是来的方便)。

存储过程出现后declare的标准处理定义就变成了非常强大的工具,可以用来为存储过程添加一些非常强大的错误处理机制。

首先需要提一点的是declare定义变量如果想定义varchar型的,必须注明参数最大长度,即declare varchar(20).

在这里我们不深究它用来定义参数的小细节

我们主要来研究declare condition 和 declare handler

declare condition 和 declare handler可以说是为了处理错误而生的。

功能上讲declare condition出现的时间比较早,功能也比较简单,它可以通过错误编号或者sqlstate来触发一各名字,说明白一点就是当某个错误编号出现的时候替换一个名字给它。这样调用的时候,我们不用去记一大串错误编号了。

它的标准语法我们可以在mysql的附注中找到。

declare condition_name condition for condition_value

condition_value:例子如下:declare errname condition for sqlstate '23000'

将返回sqlstate信息为23000的错误定名为errname

这个名字就可以被我们的绝对重头戏declare handler调用了,在declare handler中可以定义错误的处理办法,可以使用begin和end来标记语句块,可以单独使用rollback。处理的过程也可以定义为继续执行和中断存储过程。

标准语法:declare handler_type handler for condition_value[,...] sp_statement

handler_type: 处理的过程。

continue 继续执行未完成的存储过程,直至结束。(常用,默认)

| exit 出现错误即自动跳出所在的begin不再执行后面的语句。

condition_value: 处理的触发条件

sqlstate [value] sqlstate_value 不用说了,最常用的错误定义,自己去查错误列表吧。

| condition_name 我们刚刚定义的那个名字errnmae就是用在这里的。

| sqlwarning 这个太好用了,从错误编号01开始的错误。相当于错误的通配符。

| not found 和上面差不多,从02开始。

| sqlexception 上面两个中没有包括的错误它都可以用来触发,就是说你想定义只要出错就触发的话就定义出错条件为sqlwarning+sqlexception。

| mysql_error_code 错误编号,和第一个不一样,不过同样可以在错误列表从中查到,是我比较常用的。

例子declare errname condition for sqlstate '23000'; 给导致错误23000的错误定义名字为errname

declare continue handler for errname 当errname发生时作下面的处理

begin 语句开始

set @x=1; 设置@x=1

我要举报

如果感觉以上信息为低俗/不良/侵权的信息,可以点下面链接进行举报,我们会做出相应处理,感谢你的支持!

点此我要举报以上信息!

推荐资讯

大家都在看

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值