您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“函數(shù)重載Oracle和PG的異同是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“函數(shù)重載Oracle和PG的異同是什么”吧!
Oracle
Oracle不支持函數(shù)重載,一個函數(shù)名只能對應(yīng)一個函數(shù).
SQL> drop function func_1; 函數(shù)已刪除。 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 / 函數(shù)已創(chuàng)建。 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 行出現(xiàn)錯誤: ORA-00955: 名稱已由現(xiàn)有對象使用 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 行出現(xiàn)錯誤: ORA-00955: 名稱已由現(xiàn)有對象使用 SQL>
雖然參數(shù)類型不同或者參數(shù)個數(shù)不同,但Oracle可直接替換函數(shù)
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 / 函數(shù)已創(chuàng)建。 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 / 函數(shù)已創(chuàng)建。 SQL> select object_name from dba_objects where object_name = 'FUNC_1'; OBJECT_NAME -------------------------------------------------------------------------------- FUNC_1 SQL>
可通過Package實現(xiàn)函數(shù)重載.
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 / 程序包已創(chuàng)建。 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 / 程序包體已創(chuàng)建。 SQL>
PostgreSQL
PG在函數(shù)級別上就可以實現(xiàn)函數(shù)重載
[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會忽略輸出參數(shù),判斷一個函數(shù)是否是同一個函數(shù),僅判斷輸入?yún)?shù);2.如存在OUT參數(shù),PG函數(shù)無法返回結(jié)果,只能通過OUT參數(shù)返回
到此,相信大家對“函數(shù)重載Oracle和PG的異同是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。