Oracle Procedure記錄

1、定義
所謂存儲過程(Procedure),就是一組用於完成特定數據庫功能的SQL語句集,該SQL語句集經過
編譯後存儲在數據庫系統中。在使用時候,用戶通過指定已經定義的存儲過程名字並給出相應的存儲過程參數
來調用並執行它,從而完成一個或一系列的數據庫操作。
2、存儲過程的創建
Oracle存儲過程包含三部分:過程聲明,執行過程部分,存儲過程異常。
3. 使用存儲過程的好處:
1.簡化複雜的操作
2.增加數據的獨立性
3.提高安全性
4.存儲過程的語法
CREATE [OR REPLACE] PROCEDURE procedure_name [in | out | in out datatype]
IS|AS
<聲明部分>
begin
<執行部分>
exception
<異常部分>
end;
4.1無參數的存儲過程:

create or replace procedure p_test1 as
begin
for i in (select slbh,bdczh from dj_djb where slbh like '20170825%') loop
dbms_output.enable(buffer_size=>null);
dbms_output.put_line(i.slbh||','||i.bdczh);
end loop;
end;

begin
p_test1;
end;
4.2.有參的存儲過程:
4.2.1.參數名 IN 數據類型 DEFAULT 值;
定義一個輸入參數變量,用於傳遞參數給存儲過程。在調用存儲過程時,主程序的實際參數可以是常量、有值變量或表達式等。DEFAULT 關鍵字爲可選項,用來設定參數的默認值。如果在調用存儲過程時不指明參數,則參數變量取默認值。在存儲過程中,輸入變量接收主程序傳遞的值,但不能對其進行賦值。
ege:

create or replace procedure p_test2 (v_slbh in  varchar2 default 201711010025 )
as
v_bdczh dj_djb.bdczh%type;
begin
  select bdczh into v_bdczh from dj_djb where slbh =v_slbh;
  dbms_output.put_line(v_bdczh);
  end;

4.2.2.參數名 OUT 數據類型;
定義一個輸出參數變量,用於從存儲過程獲取數據,即變量從存儲過程中返回值給主程序。
在調用存儲過程時,主程序的實際參數只能是一個變量,而不能是常量或表達式。在存儲過程中,參數變量只能被賦值而不能將其用於賦值,在存儲過程中必須給輸出變量至少賦值一次。
ege:

create or replace procedure p_test3 (v_slbh varchar2 default 201711010025,v_bdczh out varchar2)
as
begin
  select bdczh into v_bdczh from dj_djb where slbh=v_slbh;
  dbms_output.put_line(v_slbh||','||v_bdczh);
  end ;
  ....調用.......
  declare
  v_1 dj_djb.bdczh%type;
   begin
    p_test3(v_bdczh=>v_1);
    end;

4.2.3.參數名 IN OUT 數據類型 DEFAULT 值;
定義一個輸入、輸出參數變量,兼有以上兩者的功能。在調用存儲過程時,主程序的實際參數只能是一個變量,而不能是常量或表達式。DEFAULT 關鍵字爲可選項,用來設定參數的默認值。在存儲過程中,變量接收主程序傳遞的值,同時可以參加賦值運算,也可以對其進行賦值。在存儲過程中必須給變量至少賦值一次。
注:如果省略IN、OUT或IN OUT,則默認模式是IN。
5.查看存儲過程錯誤原因:
select * from user_errors where name=upper(‘p_test1’);

                                                                                                   by wolihaito 2018.03.26
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章