oracle存储过程(带参数的存储过程)

Posted wangchuanfu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle存储过程(带参数的存储过程)相关的知识,希望对你有一定的参考价值。


带参数的存储过程

举例:为指定的员工涨100元的工资,打印涨前和涨后的工资

如果带参,需要指定是输入参数还是输出参数



create or replace procedure raisesalary(eno in number)

as

 ---定义一个变量保存涨前的薪水,引用emp中sal的类型作为psal的类型

 psal emp.sal%type;

begin

 ---得到员工涨前的薪水

 select sal into psal from emp where empno=eno;

 ---给该员工涨100

 update emp set sal=sal+100 where empno=eno;

 

 ---需不需要commit?

 ---注意:一般不在存储过程或者存储函数中 commit和rollback

 

 ---打印涨前和涨后的工资

 dbms_output.put_line(涨前:||psal||涨后:||(psal+100));

end;

/



一般在调用存储过程或者函数的时候再commit,这样可以保证所有执行是在同一个事物中进行的

如:

begin

    raisesalary(7839);

    raisesalary(7566);

    commit;

end;

/

一般不在存储过程中commit或者rollback,而是在调用存储过程之后再提交或回滚,这样能把存储过程封装到一个事务中。

 

如果是命令窗口就用exec 存储过程名,举个栗子:

1.如果是命令窗口就用exec 存储过程名,举个栗子:

EXEC  procedure  ;--procedure是存储过程名

 2.如果是PL/SQL窗口就用 begin  存储过程名  end; 举个栗子:

begin

  procedure;--procedure是存储过程名
end;

 3.如果是程序中调用就用 call 存储过程名 ,举个栗子:

hibernateDao.excuteSqlUpdate("Call proc_stuInfo()");//存储过程proc_stuInfo

 

以上是关于oracle存储过程(带参数的存储过程)的主要内容,如果未能解决你的问题,请参考以下文章

oracle存储过程(带参数的存储过程)

oracle存储过程输入参数能否为空

oracle 中用啥命令执行一个带参数的存储过程

SQL Server 如何执行 带参数的 存储过程

oracle带参数的存储过程,一直提示sql无效sql语句。求高手指点

oracle 存储过程中调用存储过程