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: 白猫警长


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部