Linux安全网 - Linux操作系统_Linux 命令_Linux教程_Linux黑客

会员投稿 投稿指南 本期推荐:
搜索:
您的位置: Linux安全网 > Linux集群 > Architecture > » 正文

Oracle中独立事务的学习

来源: woshiccna 分享至:

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


Tags:
分享至:
最新图文资讯
1 2 3 4 5 6
验证码:点击我更换图片 理智评论文明上网,拒绝恶意谩骂 用户名:
关于我们 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 发展历史