Oracle存储过程语法及编译过程讲解 |
您所在的位置:网站首页 › 编译的存储过程存放在数据库中 › Oracle存储过程语法及编译过程讲解 |
语法
?
1
2
3
4
5
6
7
8
9
10
CREATE [ORReplace]PROCEDURE[schema.] procedure_name
[(argument [{IN|OUT|INOUT}] datatype,
...
argument [{IN|OUT|INOUT}] datatype)]
{IS | AS}
[descriptionpart说明部分]
BEGIN
SQLSTATEMENT语句序列
[EXCEPTION例外处理]
END[procedureName过程名];
语法分析
OR REPLACE 是一个可选的关键字,建议用户使用此关键字。如果过程已经存在,该关键字将重新创建过程,这样就不必删除和重新创建过程。 关键字IS和AS均可 它们本身没有区别。IS后面是一个完整的PL/SQL块,可以定义局部变量,但不能以DECLARE开始。局部变量在过程内部存放值。 形式参数可以有三种模式:IN、OUT、INOUT。如果没有为形式参数指定模式,那么默认的模式是IN。 IN表示输入参数 OUT表示输出参数 HelloWorld! 创建第一个存储过程HelloWorld ? 1 2 3 4 5 SQL>create or replace procedure helloworld as begin dbms_output.put_line('helloworld'); end; ? 1 /注:需要在存储过程输入完成后回车,下一行输入”/”回车,才会创建成功。 当提示Procedure created表示存储过程创建成功。 调用HelloWorld! 执行 ? 1 2 SQL>set serveroutput on; SQL>exec[ute] helloworld;显示如下结果 ? 1 2 helloworld PL/SQL procedure successfully completed 编译过程注意: 存储过程不论创建是否成功,创建过程/函数命令CREATE PROCEDURE或CREATE FUNCTION都将自动把其源代码存入数据库中,而编译代码只有在编译成功后才能存入数据库中。 只有编译代码被存入到数据库的存储过程和函数才能被调用。 也就是说,如果你创建存储过程的语句是错误的,那么存储过程的源代码也会放入数据库,只是被显示为错误。 查看错误请用USER_ERRORS数据字典或用SHOW ERRORS命令,可以查询到当前系统中错误。 |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |