PL/SQL编程—包

1、PLSQL 中的包就相当于java中的package,主要好处有(1)防止命名污染,(2)功能统一,(3)允许重载,(4)可以隐藏核心代码,(5)最重要的就是断开依赖链。

2、对于一个程序需要大量的代码,需要要大量的存储过程就非得用包来实现,一次就把程序加载进去,然后就可以调用了。

3、在建包的时候,基本步骤就是(1)先create package,在里面声明procedure,(2)然后就是create package body,在package body里面编写procedure的代码即可。

4、在包里面可以建立procedure,同时也可以建立这个function,这样都封装在一起,变为私有的资源就非常便于程序的保护,同时这些代码都是一次性的调入内存中,执行起来也是非常快的。

5、总之,对于简单的程序就建立一个存储过程procedure就可以了,但是对于复杂的程序就需要建包package。
SQL> create or replace package sp_package is
  2  procedure sp_pack_pro1(id_in varchar2,name_in varchar2);
  3  function  sp_pack_fun1(mon_in number,id_in varchar2) return number;
  4  end;
  5  /
 
Package created
 
SQL>
SQL> create or replace package body sp_package is
  2  procedure sp_pack_pro1(id_in varchar2,name_in varchar2) is
  3  begin
  4  update mytest set name=name_in where id=id_in;
  5  end;
  6  function sp_pack_fun1(mon_in number,id_in varchar2)
  7  return number is
  8  sal_monsum number(7,2);
  9  begin
 10  select salary*mon_in into sal_monsum from mytest where id=id_in;
 11  return sal_monsum;
 12  end;
 13  end;
 14 
 15  /
 
Package body created
 
SQL> exec sp_package.sp_pack_pro1('wuwuwu','1');
 
PL/SQL procedure successfully completed

 

 

posted @ 2017-06-29 17:57  翎野君  阅读(233)  评论(0编辑  收藏  举报