程序包
1做用是为了实程序模块化
2程序包里面能够包含存储过程,函数,变量,游标等PL/SQL程序
3程序包相似java的jar包,存储过程,函数,变量,游标等至关jar包提供的方法
4调用程序包里面的存储过程,函数等元素时,oracle会把程序包调入内存,下次是使用,直接从内存读取。
那么这些项目属于私有项目,只能在包体中使用.
一 包的组成
包头(package):包头部分申明包内数据类型,常量,变量,游标,子程序和异常错误处理,这些元素为包的公有元素。
包主体(package body):包主体则是包定义部分的具体实现,它负责为包头中所声明子程序提供具体的实现,在包主体中还能够声明包的私有元素。
包头和包主体分开编译,并做为两个分开的对象分别存放在数据库字典中。
二 包的语法规则
包头的语法以下:
create or replace package 包名
As | IS
procedure 过程名();
Function 函数名() return 数据类型;
变量定义;
异常定义;
光标定义;
...........
...........
End 包名;
包体建立的语法:
create or replace Package Body 包名
As | IS
Procedure 过程定义;
Procedure 过程定义;
Function 函数定义;
Function 函数定义;
.........;java
end 包名;
包的开发步骤数据库
与开发存储过程相似,包的开发须要几个步骤:oracle
1. 将每一个存储过程调式正确;
2. 用文本编辑软件将各个存储过程和函数集成在一块儿;
3. 按照包的定义要求将集成的文本的前面加上包定义;
4. 按照包的定义要求将集成的文本的前面加上包主体;
5. 使用SQLPLUS或开发工具进行调式。
加密实用程序ide
ORACLE 提供了一个实用工具来加密或者包装用户的PL/SQL,它会将用户的PL/SQL改变为只有ORACLE可以解释的代码版本.
WRAP 实用工具位于$ORACLE_HOME/BIN.模块化
格式为:
WRAP INAME=<input_file_name> [ONAME=<output_file_name>]函数
wrap iname=e:\sample.txt工具
注意:在加密前,请将PL/SQL程序先保存一份,以备后用。
可使用 DROP PACKAGE 命令对不须要的包进行删除,语法以下:
DROP PACKAGE [BODY] [user.]package_name;
包与过程、函数同样,也是存储在数据库中的,能够随时查看其源码。如有须要,在建立包时能够随时查看更详细的编译错误。不须要的包也能够删除。
一样,为了不调用的失败,在更新表的结构后,必定要记得从新编译依赖于它的程序包。在更新了包说明或包体后,也应该从新编译包说明与包体。语法以下:开发工具
ALTER PACKAGE package_name COMPILE [PACKAGE|BODY|SPECIFICATION];加密
也能够经过如下数据字典视图查看包的相关。
DBA_SOURCE, USER_SOURCE, USER_ERRORS,DBA-OBJECTS 对象
如,咱们能够用:select text from user_source wherename='DEMO_PKG1';来查看咱们建立的包的源码。