您好,登錄后才能下訂單哦!
本篇內容主要講解“函數重載Oracle和PG的異同是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“函數重載Oracle和PG的異同是什么”吧!
Oracle
Oracle不支持函數重載,一個函數名只能對應一個函數.
SQL> drop function func_1; 函數已刪除。 SQL> CREATE function func_1(p_in NUMBER,p_out1 out number,p_out2 out varchar2) 2 return date 3 as 4 begin 5 return sysdate; 6 end; 7 / 函數已創建。 SQL> -- error SQL> CREATE function func_1(p_in1 NUMBER,p_out1 out number,p_in2 in varchar2) 2 return date 3 as 4 begin 5 return sysdate; 6 end; 7 / CREATE function func_1(p_in1 NUMBER,p_out1 out number,p_in2 in varchar2) * 第 1 行出現錯誤: ORA-00955: 名稱已由現有對象使用 SQL> SQL> -- error SQL> CREATE function func_1(p_in1 NUMBER,p_out1 out number,p_in2 in varchar2,p_out2 out number) 2 return date 3 as 4 begin 5 return sysdate; 6 end; 7 / CREATE function func_1(p_in1 NUMBER,p_out1 out number,p_in2 in varchar2,p_out2 out number) * 第 1 行出現錯誤: ORA-00955: 名稱已由現有對象使用 SQL>
雖然參數類型不同或者參數個數不同,但Oracle可直接替換函數
SQL> CREATE or replace function func_1(p_in1 NUMBER,p_out1 out number,p_in2 in varchar2) 2 return date 3 as 4 begin 5 return sysdate; 6 end; 7 / 函數已創建。 SQL> CREATE or replace function func_1(p_in1 NUMBER,p_out1 out number,p_in2 in varchar2,p_out2 out number) 2 return date 3 as 4 begin 5 return sysdate; 6 end; 7 / 函數已創建。 SQL> select object_name from dba_objects where object_name = 'FUNC_1'; OBJECT_NAME -------------------------------------------------------------------------------- FUNC_1 SQL>
可通過Package實現函數重載.
SQL> -- package SQL> create or replace package pk_overload 2 as 3 function func_1(p_in1 NUMBER,p_out1 out number,p_out2 out varchar2) return date; 4 function func_1(p_in1 NUMBER,p_out1 out number,p_in2 in varchar2) return date; 5 function func_1(p_in1 NUMBER,p_out1 out number,p_in2 in varchar2,p_out2 out number) return date; 6 end; 7 / 程序包已創建。 SQL> SQL> create or replace package body pk_overload 2 as 3 function func_1(p_in1 NUMBER,p_out1 out number,p_out2 out varchar2) return date 4 is 5 begin 6 null; 7 end; 8 9 function func_1(p_in1 NUMBER,p_out1 out number,p_in2 in varchar2) return date 10 is 11 begin 12 null; 13 end; 14 15 function func_1(p_in1 NUMBER,p_out1 out number,p_in2 in varchar2,p_out2 out number) return date 16 is 17 begin 18 null; 19 end; 20 21 end; 22 / 程序包體已創建。 SQL>
PostgreSQL
PG在函數級別上就可以實現函數重載
[local:/data/run/pg12]:5120 pg12@testdb=# -- overload [local:/data/run/pg12]:5120 pg12@testdb=# CREATE OR REPLACE function func_overload(p_in int,p_out1 out int,p_out2 out text) pg12@testdb-# returns record pg12@testdb-# as pg12@testdb-# $$ pg12@testdb$# declare pg12@testdb$# begin pg12@testdb$# raise notice 'func is : in,out,out'; pg12@testdb$# return; pg12@testdb$# end; pg12@testdb$# $$ LANGUAGE 'plpgsql'; CREATE FUNCTION [local:/data/run/pg12]:5120 pg12@testdb=# [local:/data/run/pg12]:5120 pg12@testdb=# CREATE OR REPLACE function func_overload(p_in1 int,p_out1 out int,p_in2 in text) pg12@testdb-# returns int pg12@testdb-# as pg12@testdb-# $$ pg12@testdb$# declare pg12@testdb$# begin pg12@testdb$# raise notice 'func is : in,out,in'; pg12@testdb$# return; pg12@testdb$# end; pg12@testdb$# $$ LANGUAGE 'plpgsql'; CREATE FUNCTION [local:/data/run/pg12]:5120 pg12@testdb=# [local:/data/run/pg12]:5120 pg12@testdb=# CREATE OR REPLACE function func_overload(p_in1 int,p_out1 out int,p_out2 out text,pi_in2 in varchar) pg12@testdb-# returns record pg12@testdb-# as pg12@testdb-# $$ pg12@testdb$# declare pg12@testdb$# begin pg12@testdb$# raise notice 'func is : in,out,out,in'; pg12@testdb$# return; pg12@testdb$# end; pg12@testdb$# $$ LANGUAGE 'plpgsql'; CREATE FUNCTION [local:/data/run/pg12]:5120 pg12@testdb=# [local:/data/run/pg12]:5120 pg12@testdb=# [local:/data/run/pg12]:5120 pg12@testdb=# -- '1' --> UNKNOW默認匹配的是text [local:/data/run/pg12]:5120 pg12@testdb=# select func_overload(1,'1'); NOTICE: func is : in,out,in func_overload --------------- (1 row) [local:/data/run/pg12]:5120 pg12@testdb=# select func_overload(1,'1'::varchar); NOTICE: func is : in,out,out,in func_overload --------------- (,) (1 row) [local:/data/run/pg12]:5120 pg12@testdb=#
PG會忽略輸出參數,判斷一個函數是否是同一個函數,僅判斷輸入參數;2.如存在OUT參數,PG函數無法返回結果,只能通過OUT參數返回
到此,相信大家對“函數重載Oracle和PG的異同是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。