语法:
CREATE [OR REPLACE] PROCEDURE procedure_name
(arg1 [mode1] datatype1,arg2 [mode2] datatype2,...)
IS [AS]
PL/SQL BLOCK;
mode用于指定输入输出参数:IN为输入参数,OUT为输出参数,当为输入参数时可以省去IN,OUT不能省去。
如果没有输入输出参数,可以省去
(arg1 [mode1] datatype1,arg2 [mode2] datatype2,...)这一行
一个带有输入,输出参数的简单的例子
CREATE OR REPLACE PROCEDURE proc_in_out_test(var_empno NUMBER,
var_ename OUT VARCHAR2) IS
BEGIN
SELECT ename INTO var_ename FROM emp WHERE empno = var_empno;
EXCEPTION
WHEN no_data_found THEN
raise_application_error(-20000, '该员工不存在');
END;
调用该过程
SQL> var vempno number;
SQL> var vename varchar2(10);
SQL> exec :vempno:=7934;
SQL> exec proc_in_out_test(:vempno,:vename);
PL/SQL procedure successfully completed
vename
---------
MILLER
SQL> exec :vempno:=7935;
SQL> exec proc_in_out_test(:vempno,:vename);
begin proc_in_out_test(:vempno,:vename); end;
ORA-20000: 该员工不存在
ORA-06512: 在 "SCOTT.PROC_IN_OUT_TEST", line 7
ORA-06512: 在 line 1
显示游标语法:
CURSOR cursor_name IS select_statement
一个简单的例子: