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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值