ORACLE的程序包不该忽视的东西

1.程序包就相当于JAVA中的类

2.程序包效率高的原因是:当程序首次调用包内函数或过程时,ORACLE将整个包调入内存,当再次访问包内元素时,ORACLE直接从内存中读取,而不需要进行磁盘I/O操作,从而使程序执行效率得到提高。

3.包有两部分组成

(1).包说明(规范)(PACKAGE SPECIFICATION):包说明部分声明包内数据类型、变量、常量、游标、子程序和异常错误处理等元素,这些元素为包的公有元素。

(2).包体(PACKAGE BODY):包主体则是包定义部分的具体实现,它定义了包定义部分所声明的游标和子程序,在包主体中还可以声明包的私有元素。

包说明和包主体分开编译,并作为两部分分开的对象存放在数据库字典中,可查看数据字典user_source, all_source, dba_source,分别了解包说明与包主体的详细信息。

4.包名是唯一的,但不同包中的公有组件可以是相同的,通过包名.公有组件名来区分

5.创建包体时,有以下几点需要注意:

包体只能在包说明被创建或编译后才能进行创建或编译。

在包体中实现的过程、函数、游标的名称必须与包说明中的过程、函数、游标一致,包括名称、参数的名称以及参数的模式(IN、OUT、IN OUT)。并建设按包说明中的次序定义包体中具体的实现。

在包体中声明的数据类型、变量、常量都是私有的,只能在包体中使用而不能被印刷体外的应用程序访问与使用。

在包体执行部分,可对包说明,包体中声明的公有或私有变量进行初始化或其它设置。

6. 在数据字典中查看程序包规范和包主体的信息
    select object_name,object_type,status from user_objects
    where lower(OBJECT_NAME) = ‘pkg_staff‘

参考文章:http://www.cnblogs.com/huyong/archive/2011/05/26/2057973.html

时间: 2024-10-13 00:29:01

ORACLE的程序包不该忽视的东西的相关文章

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

1 前言  在程序实现过程中,经常用遇到一些全局变量或常数.在程序开发过程中,往往会将该变量或常数存储于临时表或前台程序的全局变量中,由此带来运行效率降低<频繁读取临时表>或安全隐患<存于前台程序变量,可跟踪内存变量获得>.  本文主要论述将全局变量或常数存取程序包的优点和实现方法.   2 优点  2.1 执行效率比存储于临时表高,不需要频率存取临时表  2.2 将全局变量藏于最后防线<数据库>,安全性较高  2.3 在视图中可以调用程序包的变量,实现动态视图   3

ORACLE的程序包1-程序包的基础

程序包简析 oracle中的程序包简析    一 程序包的基本概念     程序包可将若干函数或者存储过程组织起来,作为一个对象进行存储.程序包通常由两部分构成,规范(specification)和主体(body). 程序包也可以包含常量和变量,包中的所有函数和存储过程都可以使用这些变量或者常量. 程序包是对相关过程.函数.变量.游标和异常等对象的封装 程序包由规范和主体两部分组成 二 规范     1 创建规范(SQL窗口)     create or replace package pkg_

Oracle基础 程序包

一.程序包 程序包是一种数据库对象,它是对相关PLSQL类型.子程序.游标.异常.变量和常量的封装.程序包包含两部分内容: 1.程序包规范:可以声明类型.变量.常量.异常.游标和子程序. 2.程序包主题:可以实现在程序包规范中定义的游标.子程序. 二.程序包规范 程序包规范包含一些应用程序课件的公共对象和类型的声明它是应用程序的借口.规范包含应用程序所需的资源,如果程序包规范只声明类型.常量.变量和异常,则不需要有程序包主体.只有子程序和游标才具有程序包主体. 语法: create [or re

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

原文:[强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!) [强烈推荐]ORACLE PL/SQL编程详解之七: 程序包的创建与应用(聪明在于学习,天才在于积累!) ——通过知识共享树立个人品牌.   继上七篇:            [推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下)            [顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之

Oracle实践--PL/SQL基础之触发器和程序包

PL/SQL基础之触发器和程序包  程序包 /* 程序包:对相关存储过程,函数,变量,游标和异常等对象的封装 有声明和主体组成 优点:1.模块化:2.更轻松的应用程序设计;3.信息隐藏;4.性能更佳 */ --程序包的声明:关键字:package is end create or replace package my_pack as procedure packageTest(v_num number); end my_pack;--也可以是 end; --程序包的主体 create or re

oracle程序包的原理和使用

程序包 程序包的定义:      程序包是对相关过程.函数.变量.游标和异常等对象的封装 程序包由规范和主体两部分组成 优点:      模块化.更轻松的应用程序设计.信息隐藏.新增功能.性能更佳. 创建包头包体的基本操作如下: create or replace package pack1 --创建包头/规范 is aa number := 1 ; --在包头声明的为公有变量 procedure update_student (update_row in student %rowtype );

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

子程序 子程序:命名的 PL/SQL 块,编译并存储在数据库中. 子程序的各个部分: 1.声明部分 2.可执行部分 3.异常处理部分(可选) 子程序的分类: 1.过程 - 执行某些操作 2.函数 - 执行操作并返回值 子程序的优点: 模块化 将程序分解为逻辑模块 可重用性 可以被任意数目的程序调用 可维护性 简化维护操作 安全性 通过设置权限,使数据更安全 存储过程 过程是用于完成特定任务的子程序. 例如: 一个购票过程可以分为很多个子过程,分别完成. 创建存储过程 创建过程的语法: CREAT

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

扩展数据库的功能 为 PL/SQL 提供对 SQL 功能的访问 用户 SYS 拥有所有程序包 是公有同义词 可以由任何用户访问 一些内置程序包 程序包名称 说明 STANDARD和DBMS_STANDARD 定义和扩展PL/SQL语言环境 DBMS_LOB 提供对 LOB数据类型进行操作的功能 DBMS_OUTPUT 处理PL/SQL块和子程序输出调试信息 DBMS_RANDOM 提供随机数生成器 DBMS_SQL 允许用户使用动态 SQL DBMS_XMLDOM 用DOM模型读写XML类型的数

Oracle基础&lt;4&gt;--程序包

一:程序包定义(包括1.程序包规范 2.程序包主体) 程序包是一种数据库对象,它是对相关pl/sql 类型.子程序.游标.异常.变量和常量的封装. 1.程序包规范:可以声明类型.变量.常量.异常.游标和子程序. 2.程序包主体:可以实现在程序包规范中定义的游标.子程序. 二:程序包规范 程序包规范包含一些应用程序课件的公共对象和类型的声明它是应用程序的借口.规范包含应用程序所需的资源,如果程序包规范只声明类型.常量.变量和异常,则不需要有程序包主体.只有子程序和游标才具有程序包主体. 语法: c