mysql存储过程中的错误怎样跟踪
关注:170 答案:2 mip版
解决时间 2021-01-16 13:34
提问者落叶、牵绊着思念
2021-01-16 08:30
mysql存储过程中的错误怎样跟踪
最佳答案
二级知识专家用命换你心
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
调用该存储过程将返回:出错了
全部回答
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
我要举报
如果感觉以上信息为低俗/不良/侵权的信息,可以点下面链接进行举报,我们会做出相应处理,感谢你的支持!
点此我要举报以上信息!
推荐资讯
大家都在看