欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

函數(shù)重載Oracle和PG的異同是什么-創(chuàng)新互聯(lián)

本篇內(nèi)容主要講解“函數(shù)重載Oracle和PG的異同是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“函數(shù)重載Oracle和PG的異同是什么”吧!

創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)由有經(jīng)驗的網(wǎng)站設(shè)計師、開發(fā)人員和項目經(jīng)理組成的專業(yè)建站團(tuán)隊,負(fù)責(zé)網(wǎng)站視覺設(shè)計、用戶體驗優(yōu)化、交互設(shè)計和前端開發(fā)等方面的工作,以確保網(wǎng)站外觀精美、成都網(wǎng)站制作、成都網(wǎng)站設(shè)計易于使用并且具有良好的響應(yīng)性。

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默認(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會忽略輸出參數(shù),判斷一個函數(shù)是否是同一個函數(shù),僅判斷輸入?yún)?shù);2.如存在OUT參數(shù),PG函數(shù)無法返回結(jié)果,只能通過OUT參數(shù)返回

到此,相信大家對“函數(shù)重載Oracle和PG的異同是什么”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

當(dāng)前文章:函數(shù)重載Oracle和PG的異同是什么-創(chuàng)新互聯(lián)
文章路徑:http://www.chinadenli.net/article34/djoipe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作App開發(fā)外貿(mào)建站小程序開發(fā)面包屑導(dǎo)航網(wǎng)站營銷

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化