閱讀976 返回首頁    go 京東網上商城


oracle中的程序包


一 程序包的基本概念

程序包可將若幹函數或者存儲過程組織起來,作為一個對象進行存儲。程序包通常由兩部分構成,規範(specification)和主體(body)。程序報也可以包含常量和變量,包中的所有函數和存儲過程都可以使用這些變量或者常量。

 


二 規範

1 創建規範(SQL窗口)

create or replace package pkg_staff as
       staffString varchar2(500);
       stafftAge number:=18;
       function get_staff_string return varchar2;
       procedure insert_staff(in_staff_id in number,in_staff_name in varchar2);
       procedure update_staff(in_staff_id in number);
       procedure delete_staff(in_staff_id in number);
end pkg_staff;


2 在數據字典中查看程序包規範的信息

select object_name,object_type,status from user_objects
where lower(OBJECT_NAME) = 'pkg_staff'

 

 

三 主體

所謂規範,就像麵向對象編程中的接口,該規範的主體必須實現該規範的所有方法。Oracle會自動尋找與主體同名的規範,看是否全部實現了該規範函數或者存儲過程。若沒有,則編譯錯誤。

1 創建主體

create or replace package body pkg_staff as
       function get_staff_string return varchar2 as
       begin
                return 'staff';
       end get_staff_string;
       procedure insert_staff(in_staff_id in number,in_staff_name in varchar2) as
       begin
                 insert into staff values (in_staff_id,in_staff_name);
       end insert_staff;
       procedure update_staff(in_staff_id in number) as
       begin
                 update staff set name = 'xy' where num = in_staff_id;
       end update_staff;
       procedure delete_staff(in_staff_id in number) as
       begin
                 delete from staff where num = '1';
       end delete_staff;
end pkg_staff;

2 在數據字典中查看程序包主體的信息

select object_name,object_type,status from user_objects
where lower(OBJECT_NAME) = 'pkg_staff'

 

 

四 調用程序包中的函數或者存儲過程


調用函數(SQL window)
select pkg_staff.get_staff_string() as result from dual


調用存儲過程(Command window)
begin
pkg_staff.delete_staff(1);
end;
/

 

 

 

最後更新:2017-04-04 07:32:04

  上一篇:go Oracle中序列的操作以及使用前對序列的初始化
  下一篇:go java中short s=s+1和s+=1的區別