zoukankan      html  css  js  c++  java
  • 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命令,可以查询到当前系统中错误。

  • 相关阅读:
    Best Time to Buy and Sell Stock(动态规划)
    word break
    Container With Most Water
    Partition List(链表的插入和删除操作,找前驱节点)
    取样问题(编程珠玑)
    统计指标
    脚本化加载文件与转储
    azkaban调度
    hive自定义UDTF函数叉分函数
    hive数据仓库建设
  • 原文地址:https://www.cnblogs.com/zgq123456/p/9897112.html
Copyright © 2011-2022 走看看