例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