本篇內(nèi)容主要講解“函數(shù)重載Oracle和PG的異同是什么”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“函數(shù)重載Oracle和PG的異同是什么”吧!
十載的蘆山網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開(kāi)發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。成都全網(wǎng)營(yíng)銷的優(yōu)勢(shì)是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整蘆山建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無(wú)論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。成都創(chuàng)新互聯(lián)公司從事“蘆山網(wǎng)站設(shè)計(jì)”,“蘆山網(wǎng)站推廣”以來(lái),每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。
Oracle
Oracle不支持函數(shù)重載,一個(gè)函數(shù)名只能對(duì)應(yīng)一個(gè)函數(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)錯(cuò)誤: ORA-00955: 名稱已由現(xiàn)有對(duì)象使用 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)錯(cuò)誤: ORA-00955: 名稱已由現(xiàn)有對(duì)象使用 SQL>
雖然參數(shù)類型不同或者參數(shù)個(gè)數(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>
可通過(guò)Package實(shí)現(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ù)級(jí)別上就可以實(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默認(rèn)匹配的是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會(huì)忽略輸出參數(shù),判斷一個(gè)函數(shù)是否是同一個(gè)函數(shù),僅判斷輸入?yún)?shù);2.如存在OUT參數(shù),PG函數(shù)無(wú)法返回結(jié)果,只能通過(guò)OUT參數(shù)返回
到此,相信大家對(duì)“函數(shù)重載Oracle和PG的異同是什么”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!