oracle超级管理员账号PL_SQL程序打包简析

PL/SQL 可以让我们把逻辑相关的类型、变量、游标和子程序放在一个包内,这样更

加清楚易理解。包通常有两部分组成:包说明部分和包体部分。包说明部分是应用程序的接

口,它"声明"了类型、常量、变量、异常、游标和可以使用的子程序。包体用于实现包说明

部分声明的子程序和游标。

下面的例子是把两个雇用相关的过程进行打包:

CREATE PACKAGE emp_actions AS — package specification

PROCEDURE hire_employee(empno NUMBER, enaoracle账号me CHAR, …);

PROCEDURE fire_employee(emp_id NUMBER);

END emp_actions;

CREATE PACKAGE BODY emp_actions AS — package body

PROCEDURE hire_employee(empno NUMBER, ename CHAR, …); IS

BEGIN  www.2cto.com  

INSERT INTO emp

VALUES (empno, ename, …);

END hire_employee;

PROCEDURE fire_employee(emp_id NUMBER) IS

BEGIN

DELETE FROM emp

WHERE empno = emp_id;

END fire_employee;

END emp_actions;

只有在包说明中声明的内容对应用程序是可见的,而包体中的内容是不可见,无法访

问的。包被编译后会存放到数据库中,当我们首次调用包中的子程序时,整个包就会被加载

到内存当中,所以,后续的调用不再涉及到磁盘的读取问题。因此,包可以提高效率改善性

能。

 

 

 

 

作者 liwei888

此条目发表在oracle metalink账号分类目录,贴了标签。将固定链接加入收藏夹。