exit遇到错误就会执行特定语句
continue遇到错误会忽略错误继续执行
创建表的代码如下:
CREATE TABLE `_t1`(
`id` INT(11) NOT NULL AUTO_INCREMENT PRIMARY KEY,
`val1` VARCHAR(20) DEFAULT NULL,
`varl2` INT(11) DEFAULT NULL
)ENGINE=INNODB CHARSET=utf8;
测试exit代码如下:
DELIMITER $
CREATE PROCEDURE `testexception1`()
BEGIN
DECLARE _var,_err INT DEFAULT 0;
DECLARE EXIT HANDLER FOR SQLEXCEPTION
BEGIN
SET _err=2;
SELECT _err;
END;
INSERT INTO _t1(varl1,varl2)VALUE(2012,'hello');
END $
DELIMITER ;
call testexcepton1();
运行结果如下:

测试continue代码如下:
delimiter $
CREATE PROCEDURE `testexception`()
begin
declare _var,_err int default 0;
declare continue handler for sqlexception,sqlwarning,not found set _err=1;
insert into _t1(varl1,varl2)value(2012,'hello');
if _err=1 then
set _var=2;
end if;
select case when _var=2 then
'出错了'
else _var end;
end $
delimiter ;
call testexception();
运行结果如下:

本文介绍了在MySQL存储过程中,如何使用exit和continue来处理异常。当遇到错误时,exit会立即执行特定语句并终止流程,而continue则会忽略错误并继续执行下一个循环。通过示例代码和运行结果,详细解析了这两个关键字的用法。
1万+

被折叠的 条评论
为什么被折叠?



