oracle使用者自訂函數

來源:互聯網
上載者:User

 

使用者定義函數是儲存在資料庫中的代碼塊,可以把值返回到調用程式。調用時如同系統函數一樣,如max(value)函數,其中,value被稱為參數。函數參數有3種類型。IN 參數類型:表示輸入給函數的參數。OUT 參數類型:表示參數在函數中被賦值,可以傳給函數調用程式。IN OUT參數類型:表示參數既可以傳值也可以被賦值。 1、文法格式:SQL文法方式建立的文法格式為:CREATE OR REPLACE FUNCTION function_name         /**//*函數名稱*/
(
Parameter_name1,mode1 datatype1,            /**//*參數定義部分*/
Parameter_name2,mode2 datatype2,
Parameter_name3,mode3 datatype3

)
RETURN return_datatype                /**//*定義傳回值類型*/
IS/AS
BEGIN
      Function_body                  /**//*函數體部分*/
      RETURN scalar_expression                        /**//*返回語句*/
END function_name;

  

說明:function_name::使用者定義的函數名。函數名必須符合標示符的定義規則,對其所有者來說,該名在資料庫中是唯一的。parameter:使用者定義的參數。使用者可以定義一個或多個參數。mode:參數類型。datatype:使用者定義參數的資料類型。return_type::使用者傳回值的資料類型。函數返回scalar_expression運算式的值,function_body函數體由pl/sql語句構成。 2、樣本函數代碼:create or replace function T01001_count
return number
is
count_T01001 number;
begin
select count(*) into count_T01001 from T01001;
return(count_T01001);
end T01001_count;                  --記得一定要打分號

調用:
declare
i number;
begin
i:=T01001_count();
dbms_output.put_line(to_char(i));
end;                 --記得一定要打分號

 

注意:(1)    如果函數沒有參數,那麼函數名後不應該要括弧;(2)    建立函數的時候end後面一定要記得寫函數名;

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.