本篇内容主要讲解“函数重载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进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。