图解Oracle包实例
? ? 以下使用SQL Developer,使用Oracle SCOTT賬號自帶emp表,創建包。
1?在包中定義record類型,并在匿名塊中調用
--在包中自定義類型
create or replace package my_bao
as
type emp_type is record(
? ? gh emp.empno%type,
? ? xm emp.ename%type,
? ? gz emp.sal%type
);
end;
創建之后刷新一下,左側視圖 程序包 下出來所創建內容;
2 調用,
declare
v1 my_bao.emp_type;
begin
select empno,ename,sal into v1 from emp where empno=7900;
dbms_output.put_line('工號='||v1.gh);
dbms_output.put_line('姓名='||v1.xm);
dbms_output.put_line('工資='||v1.gz);
end;
結果如下圖;
? ? 如果DBMS輸出中沒有內容,點擊上圖中最右側的像書的頁的那個小圖標,打開DBMS輸出;
3?在包中定義過程hello和函數f_add(p1,p2)
--定義包規范
create or replace package my_bao2
as
type emp_type is record(
? ? gh emp.empno%type,
? ? xm emp.ename%type,
? ? gz emp.sal%type
);
procedure hello(p_name varchar2);
function f_add(p1 number,p2 number) return number;
end;
4?實現包規范,即包體(package body)
create or replace package body my_bao2
as
type emp_type is record(
? ? gh emp.empno%type,
? ? xm emp.ename%type,
? ? gz emp.sal%type
);
procedure hello(p_name varchar2)
as
begin
? ? dbms_output.put_line('hello,'||p_name);
end;
function f_add(p1 number,p2 number) return number
as
? ? v1 number;
begin
? ? ?v1:=p1+p2;
? ? ?return v1;
end;
end;
5 調用
select my_bao2.f_add(1,2) from dual;
6 調用
call my_bao2.hello('oracle');
7?包中重載方法
重載的要點就是名稱一樣,而參數的類型或者個數不同。
定義代碼:
create or replace package my_bao3
as
function f_add(p1 number,p2 number) return number;
function f_add(p1 varchar,p2 varchar) return number;
end;
包體:
create or replace
package body my_bao3
as
function f_add(p1 number,p2 number) return number
as
? ? v1 number;
begin
? ? ?v1:=p1+p2;
? ? ?return v1;
end;
ction f_add(p1 varchar,p2 varchar) return number
as
? ? v1 number;
begin
? ? ?v1:=p1+p2;
? ? ?return v1;
end;
end;
8 調用
select my_bao3.f_add(1,2) from dual;
9 調用
select my_bao3.f_add('6','2') from dual;
oracle會根據參數類型自動選擇調用哪個函數;
總結
以上是生活随笔為你收集整理的图解Oracle包实例的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 图解Oracle存储过程教程
- 下一篇: 图解Oracle RMAN备份入门