例1 :嵌套游标
CREATE PROCEDURE card_rollback() BEGIN DECLARE done INT DEFAULT 0; -- 游标结束标志 DECLARE value_ INT ; DECLARE cur CURSOR FOR select id from test ;-- table or view DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1 ; -- 读取完是标志结束 open cur; set @@autocommit=0; -- 手动提交 REPEAT FETCH cur INTO value_ ; -- 重游标中取值 if not done then select '1' ; -- do something BEGIN DECLARE cur_0 CURSOR FOR select id from test ;-- 嵌套游标 end ; end if; UNTIL done END REPEAT; CLOSE cur; end ;
?
例2:异常处理
delimiter // -- 重新定义换行符
drop PROCEDURE if EXISTS t_insert_table//
create procedure t_insert_table()
begin
/** 标记是否出错 */
declare t_error int default 0;
declare t_warn int default 0;
/** 如果出现sql异常,则将t_error设置为1后退出操作 */
declare CONTINUE handler for SQLWARNING set t_warn = 1; -- 出错处理
DECLARE EXIT HANDLER FOR SQLEXCEPTION set t_error = 1 ;
/** 显式的开启事务,它开启后,事务会暂时停止自动提交*/
-- start transaction;
/** 关闭事务的自动提交 */
set autocommit = 0;
insert into t_bom_test(parent_id,child_id) values('D','abc');
insert into t_trigger_test(name,age) values('zhangsan',null);
/** 标记被改变,表示事务应该回滚 */
if t_error=1 then
select 'ee' ;
rollback; -- 事务回滚
else
commit; -- 事务提交
end if;
-- rollback;
-- commit;
end//
delimiter ;
?
?
语法定义:
14.1、创建存储过程和函数
14.1.1、创建存储过程
CREATE?PROCEDUREsp_name?([proc_parameter[,...]])
[characteristic...]?routine_body
?
procedure?发音?[pr?'si:d??]
?
proc_parameter???????????IN|OUT|INOUT?param_name?type
characteristic???????????????n.?特征;特性;特色
?????????LANGUAGESQL?????????????????????默认,routine_boyd由SQL组成
?????????[NOT]DETERMINISTIC
