一、程序包

  程序包是一种数据库对象,它是对相关PLSQL类型、子程序、游标、异常、变量和常量的封装。程序包包含两部分内容:

  1、程序包规范:可以声明类型、变量、常量、异常、游标和子程序。

  2、程序包主题:可以实现在程序包规范中定义的游标、子程序。

二、程序包规范

  程序包规范包含一些应用程序课件的公共对象和类型的声明它是应用程序的借口。规范包含应用程序所需的资源,如果程序包规范只声明类型、常量、变量和异常,则不需要有程序包主体。只有子程序和游标才具有程序包主体。

  语法:

  create [or replace] package package_name

  is|as

    [public type and item declations]

    [subprogram specifications]

  end [package_name]

  说明:

  package_name:包的名称。

  public type and item declations:声明公共类型、常量、变量、异常和游标等。

  subprogram specifications:声明PL/SQL子程序,也就是存储过程和函数。

  在程序包规范中声明的项也可以再程序包之外使用。这样的项成为“公用对象”。

  

  例:

  1. --程序包规范的声明
  2. CREATE OR REPLACE PACKAGE PACKAGE_ME IS
  3. PROCEDURE PRO_EMP_SELECT(ENO NUMBER); --声明一个存储过程:根据员工编号查询员工信息
  4. FUNCTION FUN_EMP_SELECT(ENO NUMBER) RETURN NUMBER; --声明一个函数,根据员工编号查询员工工资。
  5. END PACKAGE_ME;

三、程序包主体:

  程序包主题包含了在程序包规范中声明的每个游标和子程序的具体实现。私有声明也可以包含在程序包主体中。程序包主题部分初始化是可选的,它可用于初始化程序包包中的变量。程序包的初始化部分既不能调用程序包,也不能将参数传递给程序包,而且,初始化部分仅运行一次。

  create [or replace] package body package_name

  is|as    

    [public type and item declarations]

    [subprogram bodies]

  [begin

    initialization_statements]

  end [package_name]

  说明:

  public type and item declarations:声明变量、常量、游标、异常或类型。

  subprogram bodies:定义公共和私有PL/SQL子程序。

  initialization_statements:程序包中规范代码的实现。

  

  例:对上面所声明的规范部分的存储过程和函数提供实现。  

  1. --创建程序包主体,提供程序包内容的实现,和存储过程、函数的声明一致
  2. CREATE OR REPLACE PACKAGE BODY PACKAGE_ME IS
  3. PROCEDURE PRO_EMP_SELECT(ENO NUMBER) AS
  4. V_NAME EMP.ENAME%TYPE;
  5. V_SAL EMP.SAL%TYPE;
  6. BEGIN
  7. SELECT ENAME, SAL INTO V_NAME, V_SAL FROM EMP WHERE EMPNO = ENO;
  8. DBMS_OUTPUT.PUT_LINE('name:' || V_NAME || ' sal:' || V_SAL);
  9. END PRO_EMP_SELECT;
  10.  
  11. FUNCTION FUN_EMP_SELECT(ENO NUMBER) RETURN NUMBER AS
  12. V_SAL EMP.SAL%TYPE;
  13. BEGIN
  14. SELECT SAL INTO V_SAL FROM EMP WHERE EMPNO = ENO;
  15. RETURN V_SAL;
  16. END FUN_EMP_SELECT;
  17. END PACKAGE_ME;

四、调用程序包  

  1. DECLARE
  2. v_sal emp.sal%TYPE;
  3. BEGIN
  4. package_me.PRO_EMP_SELECT(7788); --调用方式和调用存储过程方式一样,不过需要在存储过程前添加程序包名
  5. v_sal := package_me.FUN_EMP_SELECT(7788); --调用方式和调用函数方式一样,不过需要在函数前添加程序包名
  6. dbms_output.put_line(v_sal);
  7. END;

Oracle基础 程序包的更多相关文章

  1. Oracle基础<4>--程序包

    一:程序包定义(包括1.程序包规范 2.程序包主体) 程序包是一种数据库对象,它是对相关pl/sql 类型.子程序.游标.异常.变量和常量的封装. 1.程序包规范:可以声明类型.变量.常量.异常.游标 ...

  2. Oracle存储过程和程序包

    一.为什么要用存储过程? 如果在应用程序中经常需要执行特定的操作,可以基于这些操作简历一个特定的过程.通过使用过程可以简化客户端程序的开发和维护,而且还能提高客户端程序的运行性能. 二.过程的优点? ...

  3. linux基础之程序包管理(rpm,yum)

    一.rpm 安装:rpm { -i | --install } [ install-options ] PACKAGE_FILE... -v: 显示安装时的详细信息 -vv: 显示许多难以阅读的调试信 ...

  4. Oracle编程入门经典 第11章 过程、函数和程序包

    目录 11.1          优势和利益... 1 11.2          过程... 1 11.2.1       语法... 2 11.2.2       建立或者替换... 2 11.2 ...

  5. Oracle数据库程序包全局变量的应用

    1 前言  在程序实现过程中,经常用遇到一些全局变量或常数.在程序开发过程中,往往会将该变量或常数存储于临时表或前台程序的全局变量中,由此带来运行效率降低<频繁读取临时表>或安全隐患< ...

  6. [强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!)

    原文:[强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!) [强烈推荐]ORACLE PL/SQL编程详解之七: 程序包的创建与应用(聪明在于学习,天 ...

  7. Oracle学习笔记十四 内置程序包

    扩展数据库的功能 为 PL/SQL 提供对 SQL 功能的访问 用户 SYS 拥有所有程序包 是公有同义词 可以由任何用户访问 一些内置程序包 程序包名称 说明 STANDARD和DBMS_STAND ...

  8. Oracle学习笔记十二 子程序(存储过程、自定函数)和程序包

    子程序 子程序:命名的 PL/SQL 块,编译并存储在数据库中.   子程序的各个部分: 1.声明部分 2.可执行部分 3.异常处理部分(可选) 子程序的分类: 1.过程 - 执行某些操作 2.函数 ...

  9. Oracle程序包

    程序包由两部分构成:规范(specification)和主体(body). 创建表 create table PEOPLE ( ID NUMBER primary key not null, NAME ...

随机推荐

  1. OpenGL入门学习(四)

    http://blog.csdn.net/sun6255028/article/details/5090055 OpenGL支持两种颜色模式:一种是RGBA,一种是颜色索引模式.无论哪种颜色模式,计算 ...

  2. 解析Linux内核的基本的模块管理与时间管理操作---超时处理【转】

    转自:http://www.jb51.net/article/79960.htm 这篇文章主要介绍了Linux内核的基本的模块管理与时间管理操作,包括模块加载卸载函数的使用和定时器的用法等知识,需要的 ...

  3. Centos 查看硬盘空间

    df -h du -ah --max-depth=1 目录深度为1 -h:以人类可读的方式显示 -a:显示目录占用的磁盘空间大小,还要显示其下目录和文件占用磁盘空间的大小 -s:显示目录占用的磁盘空间 ...

  4. js5秒后自动关闭本页面及5秒钟后自动跳转指定页面的方法

    5秒钟后自动关闭 <!DOCTYPE HTML> <html> <head> <title>倒计时自动关闭/跳转页面</title> < ...

  5. 一篇好文档,请Thymeleaf Layout Dialect

    Thymeleaf Layout Dialect https://ultraq.github.io/thymeleaf-layout-dialect/ This will introduce the  ...

  6. 计蒜客 28319.Interesting Integers-类似斐波那契数列-递推思维题 (Benelux Algorithm Programming Contest 2014 Final ACM-ICPC Asia Training League 暑假第一阶段第二场 I)

    I. Interesting Integers 传送门 应该是叫思维题吧,反正敲一下脑壳才知道自己哪里写错了.要敢于暴力. 这个题的题意就是给你一个数,让你逆推出递推的最开始的两个数(假设一开始的两个 ...

  7. 在sae中运行web.py应用

    sae 是新浪推出的PaaS业务,可以提供免运维的容器服务,官方网站( https://www.sinacloud.com/ ) 假设您已经在本地开发好了web.py 应用,您可以通过github客户 ...

  8. cdq分治浅谈

    $cdq$分治浅谈 1.分治思想 分治实际上是一种思想,这种思想就是将一个大问题划分成为一些小问题,并且这些小问题与这个大问题在某中意义上是等价的. 2.普通分治与$cdq$分治的区别 普通分治与$c ...

  9. codevs 2837 考前复习——01背包

     时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Description Aiden马上要考试了,可他还没怎么复习,于是他 ...

  10. SPOJ 3267 DQUERY - D-query (主席树)(区间数的种数)

    DQUERY - D-query #sorting #tree English Vietnamese Given a sequence of n numbers a1, a2, ..., an and ...