oracle 存储过程 行锁

问题:1.要求通过存储过程实现程序运行的并发控制。

         2.存储过程一个输入参数一个输出参数,输入要运行的程序名称,判断该程序是否在运行输出参数返回程序状态

         3.解决问题:当两个用户同时访问同一程序时,都检索到该程序未运行,同时运行,并发失效。

create or replace procedure (prog_name_in varchar2(50),run_flag_out out varchar2(50))

is

v_run_flag varchar2(10);

 

begin

  select run_flag into v_run_flag from tb_prog_stauts

           where prog_name = prog_name_in for update ;

  if(v_run_flag = 'Y') then

     run_flag_out := '程序运行中';

  end if;

  if(v_run_flag ='N') then

     fun_flag_out := '程序可以运行';

  end if;

 Exception

     when others then

     rollback;

commit;

end;

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值