oracle独立事务,Oracle中独立事务的处理
1:
创建存储过程emp_p2,查询id为0的雇员的信息,并回滚事务
create or replace procedure emp_p2 as
a varchar2(50);
begin
select e.name into a from employees e where e.id='0';
dbms_output.put_line('p2:' || a);
rollback;
end emp_p2;
创建存储过程emp_p1,更新id为0的雇员信息
create or replace procedure emp_p1 as
b varchar2(50);
begin
update employees e set e.name='白猫警长' where e.id='0';
emp_p2();
select e.name into b from employees e where e.id='0';
dbms_output.put_line('p1: ' || b);
end emp_p1;
运行存储过程emp_p1,
begin
emp_p1();
end;
运行结果:
p2: 白猫警长
p1: 黑猫警长
说明在emp_p2存储过程中的rollback影响了emp_p1存储过程
2:为了使emp_p2中的存储过程不影响到emp_p1存储过程,我们可以把emp_p2设置为自主的存储过程
create or replace procedure emp_p2 as
a varchar2(50);
pragma autonomous_transaction;
begin
select e.name into a from employees e where e.id='0';
dbms_output.put_line('p2:' || a);
rollback;
end emp_p2;
再调用存储过程emp_p1,输出结果为:
p2: 黑猫警长
p1: 白猫警长
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
