1.  
  1. 带参数的存储过程
  2. 举例:为指定的员工涨100元的工资,打印涨前和涨后的工资
  3. 如果带参,需要指定是输入参数还是输出参数
  4. create or replace procedure raisesalary(eno in number)
  5. as
  6.  
  7. ---定义一个变量保存涨前的薪水,引用empsal的类型作为psal的类型
  8. psal emp.sal%type;
  9. begin
  10.  
  11. ---得到员工涨前的薪水
  12.  
  13. select sal into psal from emp where empno=eno;
  14. ---给该员工涨100
  15.  
  16. update emp set sal=sal+100 where empno=eno;
  17. ---需不需要commit
  18.  
  19. ---注意:一般不在存储过程或者存储函数中 commitrollback
  20.  
  21.  
  22. ---打印涨前和涨后的工资
  23. dbms_output.put_line(\'涨前:\'||psal||\'涨后:\'||(psal+100));
  24. end;
  25. /
  26. 一般在调用存储过程或者函数的时候再commit,这样可以保证所有执行是在同一个事物中进行的
  27. 如:
  28. begin
  29. raisesalary(7839);
  30. raisesalary(7566);
  31. commit;
  32. end;
  33. /
  1.  

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

  1.  

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

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

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

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

begin

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

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

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

 

版权声明:本文为wangchuanfu原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/wangchuanfu/p/10960550.html