MYSQL存储过程之异常处理exit、continue

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

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();

运行结果如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值