基于oracle 的PL/SQL编程 - 存储过程

接上篇,游标使用的语句,相当于一段匿名的函数,窗口关闭了就不存在了。如果想要窗口关闭了,还能继续执行那段代码,就需要存储过程了: PLSQL是指一个个PLSQL的业务处理过程存储起来进行复用,这些被存储起来的PLSQL程序称之为存储过程。

语法:

plsql如何创建存储过程:

1.  一个简单的存储过程,存储过程名称为 p_hello

1 create or replace procedure p_hello is
2 --如果需要,在此处声明变量
3 begin
4   dbms_output.put_line('hello world'); 
5 end p_hello;
6 -- 写完点击执行,这段语句会被存储起来

注意,上面存储过程中 is  关键字可以换成as 关键字,一样的效果

存储过程的调用:打开一个测试窗口,在begin 和end之间写上存储过程名,然后点击执行,就是调用了一次存储过程

   执行结果:

1 begin
2   -- Call the procedure
3   p_hello;
4 end;

 2.带入参存储过程:

扫描二维码关注公众号,回复: 1437962 查看本文章
 1 --查询并打印某个员工的姓名,薪水,要求调用时传入员工编号,控制台自动打印
 2 create or replace procedure p_empInfo(i_empno IN emp.empno%TYPE) as
 3   --声明变量
 4   v_ename emp.ename%TYPE;
 5   v_sal   emp.sal%TYPE;
 6 begin
 7   select ename, sal into v_ename, v_sal from emp where empno = i_empno;
 8   dbms_output.put_line('员工编号:' || i_empno || ',姓名:' || v_ename || ',薪水:' || v_sal);
 9 
10 end p_empInfo;

写完点击执行,编译该存储过程。

调用:打开一个测试窗口,

1 -- 调用带入参存储过程
2 begin
3   p_empInfo(7839);
4   p_empInfo(7902);
5 end;

结果:

3. 带入参及返回值的存储过程:输入员工号查询某个员工(7839)信息,要求将薪水作为返回值输出,给调用的程序使用,比如java 程序,c# .net程序等

1 --输入员工号查询某个员工(7839)信息,要求讲薪水作为返回值输出,给调用的程序使用
2 create or replace procedure p_empInfo2(i_empno IN emp.empno%TYPE, o_sal out emp.Sal%TYPE) as
3 
4 begin
5   select sal into o_sal from emp where empno = i_empno;
6   
7 end p_empInfo2;

在测试窗口中调用该存储过程,需要事先定义一个变量作为 存储过程返回值的接收参数,在打印语句中打印该参数的值,执行该语句, 输出结果5000.00 

1 -- Created on 2018/6/3 by ADMINISTRATOR 
2 declare 
3   
4   v_sal emp.sal%TYPE;
5 begin
6   p_empInfo2(7839,v_sal);
7   dbms_output.put_line(v_sal);
8     
9 end;

猜你喜欢

转载自www.cnblogs.com/enjoyjava/p/9131169.html