1. 过程的语法结构 完整的过程结构如下: create or replace PRocedure 过程名 as 声明语句段; begin 执行语句段; exception 异常处理语句段; end; 2. 过程的特点 过程是有名称的程序块,as要害词代替了无名块的declare。 3. 创建过程实例 在【SQLPlus Worksheet】中执行下列PL/SQL程序,该程序将创建名为tempprocedure的过程,create是创建过程的标识符,replace表示若同名过程存在将覆盖原过程。该过程定义了一个变量,其类型和testtable数据表中的currentdate字段类型相同,都是日期型,将数据表中的recordnumber字段为88的currentdate字段内容送入变量中,然后输出结果。 ――――――――――――――――――――――――――――――――――――― set serveroutput on create or replace procedure tempuser.tempprocedure as tempdate tempuser.testtable.currentdate%type; begin select currentdate into tempdate from testtable where recordnumber=88; dbms_output.put_line(to_char(tempdate)); end; ――――――――――――――――――――――――――――――――――――― 【配套程序位置】:第9章/ createprocedure.sql。 执行结果如图9.41所示。
在【SQLPlus Worksheet】中执行下列PL/SQL程序,执行结果如图9.45所示。 ――――――――――――――――――――――――――――――――――――― set serveroutput on begin tempprocedure; end; ――――――――――――――――――――――――――――――――――――― 【配套程序位置】:第9章/ executeprocedure.sql。
在Oracle中,创建好的过程可以被任何程序调用。
带参数的过程
前面介绍的过程没有参数,主程序和过程没有数据的传递,下面介绍带参数的过程的设计和使用。 1. 参数类型 在PL/SQL过程中,可以有3种类型的参数。 in参数:读入参数,主程序向过程传递参数值。 out参数:读出参数,过程向主程序传递参数值。 in out 参数:双向参数,过程与主程序双向交流数据。 2. 定义带参数的过程 在下面的PL/SQL程序代码中,将创建三个调用参数。 tempdeptno:类型为in,与scott.dept.deptno的类型一致,为数值型。 tempdname:类型为out,与scott.dept.dname的类型一致,为字符型。 temploc:类型为in out,与scott.dept.loc类型一致,为字符型。 创建两个过程内参数。 loc1:与scott.dept.loc的类型一致,为字符型。 dname1:与scott.dept.dname的类型一致,为字符型。 该带参数的过程的功能是从数据表scott.dept中寻找deptno字段等于tempdeptno调用参数值的dname和loc字段,和其他字符组合,送给两个出口参数。 以system用户名、sysdba身份登录【SQLPlus Worksheet】,执行下列PL/SQL程序,执行结果如图9.46所示。 ――――――――――――――――――――――――――――――――――――― Set serveroutput on create or replace procedure scott.tempprocedure( tempdeptno in scott.dept.deptno%type, tempdname out scott.dept.dname%type, temploc in out scott.dept.loc%type)as loc1 scott.dept.loc%type; dname1 scott.dept.dname%type; begin select loc into loc1 from scott.dept where deptno=tempdeptno; select dname into dname1 from scott.dept where deptno=tempdeptno; temploc:='地址:'loc1; tempdname:='姓名'dname1; end; ――――――――――――――――――――――――――――――――――――― 【配套程序位置】:第9章/ createscottprocedure.sql。