MySql捕获sql语句异常的方法
2011-07-11 11:51
477 查看
有使用过VS2005开发工具的朋友或者其他语句如js中都有Try catch 语句块,那么在mysql中是否能有SQLserver的@@error变量呢,或者如c#中的try catch语法呢?
答案是肯定的,实例代码如下:
DROP PROCEDURE IF EXISTS sp_call_jobs;
CREATE PROCEDURE sp_call_jobs()
NOT DETERMINISTIC
SQL SECURITY DEFINER
COMMENT ''
BEGIN
declare _row,_err,_count int default 0;
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION,SQLWARNING,NOT FOUND set _err=1;
while _row<3 DO
START TRANSACTION;
insert into t1(cond_val)values(null);
COMMIT;
if _err=1 then
set _count=_count+1;
end if;
set _row=_row+1;
end while;
select _count;
END;
语句:
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION,SQLWARNING,NOT FOUND set _err=1;
作用是当遇到SQLEXCEPTION,SQLWARNING,NOT FOUND 错误时,设置_err=1并执行CONTINUE操作,即继续执行后面的语句。
这就与c#中的try catch语法很像。
而且在执行可能出错的语句的时候我们用事务语句:START TRANSACTION; …… COMMIT; 可以保证完整性
答案是肯定的,实例代码如下:
DROP PROCEDURE IF EXISTS sp_call_jobs;
CREATE PROCEDURE sp_call_jobs()
NOT DETERMINISTIC
SQL SECURITY DEFINER
COMMENT ''
BEGIN
declare _row,_err,_count int default 0;
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION,SQLWARNING,NOT FOUND set _err=1;
while _row<3 DO
START TRANSACTION;
insert into t1(cond_val)values(null);
COMMIT;
if _err=1 then
set _count=_count+1;
end if;
set _row=_row+1;
end while;
select _count;
END;
语句:
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION,SQLWARNING,NOT FOUND set _err=1;
作用是当遇到SQLEXCEPTION,SQLWARNING,NOT FOUND 错误时,设置_err=1并执行CONTINUE操作,即继续执行后面的语句。
这就与c#中的try catch语法很像。
而且在执行可能出错的语句的时候我们用事务语句:START TRANSACTION; …… COMMIT; 可以保证完整性
相关文章推荐
- MySQL中捕获低效SQL语句的配置以及检测SQL语句效率的方法
- 浅谈MySQL中优化sql语句查询常用的30种方法
- Shell脚本中执行sql语句操作mysql的5种方法
- 浅谈MySQL中优化sql语句查询常用的30种方法
- Mysql中Sql语句最大长度设置方法
- Mysql常用30种SQL查询语句优化方法
- MySQL中优化sql语句查询常用的30种方法
- sqlserver/mysql/oracle实现sql语句分页方法
- Shell脚本中执行sql语句操作mysql的5种方法
- 浅谈MySQL中优化sql语句查询常用的30种方法
- 查询mysql中执行效率低的sql语句的方法
- Mysql5.7.11中groupby的sql语句引起的异常
- MySQL大数据量分页查询方法及其优化 ---方法1: 直接使用数据库提供的SQL语句 ---语句样式: MySQL中,可用如下方法: SELECT * FROM 表名称 LIMIT M,N ---适
- 浅谈MySQL中优化sql语句查询常用的30种方法
- 浅谈MySQL中优化sql语句查询常用的30种方法
- 浅谈MySQL中优化sql语句查询常用的30种方法
- Mysql常用SQL查询语句优化方法
- MySQL循环遍历执行查询SQL语句结果的方法
- 浅谈MySQL中优化sql语句查询常用的30种方法