這篇文章主要講解了“Oracle與PostgreSQL的區別有哪些”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Oracle與PostgreSQL的區別有哪些”吧!
創新互聯建站專業提供成都溫江機房服務,為用戶提供五星數據中心、電信、雙線接入解決方案,用戶可自行在線購買成都溫江機房服務,并享受7*24小時金牌售后服務。Oracle
SQL> CREATE OR REPLACE function func_out(pi_in NUMBER,pi_out1 out number,pi_out2 out varchar2) 2 return date 3 as 4 v_date date; 5 begin 6 v_date := sysdate; 7 pi_out1 := pi_in; 8 pi_out2 := pi_in; 9 return v_date; 10 end; 11 / 函數已創建。 SQL> SQL> set serveroutput on SQL> declare 2 v_date date; 3 v_out1 number; 4 v_out2 varchar2(200); 5 begin 6 v_date := func_out(1,v_out1,v_out2); 7 dbms_output.put_line('v_date = '||v_date||';v_out1 = '||v_out1||';v_out2 = '||v_out2); 8 end; 9 / v_date = 14-2月 -20;v_out1 = 1;v_out2 = 1 PL/SQL 過程已成功完成。 SQL>
輸出參數分別是number、varchar2,函數返回date類型。
PostgreSQL
[local:/data/run/pg12]:5120 pg12@testdb=# CREATE OR REPLACE function func_out(pi_in int,pi_out1 out int,pi_out2 out text) pg12@testdb-# returns date pg12@testdb-# as pg12@testdb-# $$ pg12@testdb$# declare pg12@testdb$# v_date date; pg12@testdb$# begin pg12@testdb$# v_date := current_date(); pg12@testdb$# pi_out1 := pi_in; pg12@testdb$# pi_out2 := to_char(pi_in); pg12@testdb$# return v_id; pg12@testdb$# end; pg12@testdb$# $$ LANGUAGE 'plpgsql'; ERROR: function result type must be record because of OUT parameters [local:/data/run/pg12]:5120 pg12@testdb=#
提示結果類型必須為record
[local:/data/run/pg12]:5120 pg12@testdb=# CREATE OR REPLACE function func_out(pi_in int,pi_out1 out int,pi_out2 out text) pg12@testdb-# returns record pg12@testdb-# as pg12@testdb-# $$ pg12@testdb$# declare pg12@testdb$# v_date date; pg12@testdb$# begin pg12@testdb$# v_date := current_date; pg12@testdb$# pi_out1 := pi_in; pg12@testdb$# pi_out2 := to_char(pi_in); pg12@testdb$# return null; pg12@testdb$# end; pg12@testdb$# $$ LANGUAGE 'plpgsql'; ERROR: RETURN cannot have a parameter in function with OUT parameters LINE 11: return null; ^ [local:/data/run/pg12]:5120 pg12@testdb=#
改為record后,返回null值,提示如存在OUT參數不允許返回值。
[local:/data/run/pg12]:5120 pg12@testdb=# CREATE OR REPLACE function func_out(pi_in int,pi_out1 out int,pi_out2 out text) pg12@testdb-# returns record pg12@testdb-# as pg12@testdb-# $$ pg12@testdb$# declare pg12@testdb$# v_date date; pg12@testdb$# begin pg12@testdb$# v_date := current_date; pg12@testdb$# pi_out1 := pi_in; pg12@testdb$# pi_out2 := pi_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=# do pg12@testdb-# $$ pg12@testdb$# declare pg12@testdb$# v_ret record; pg12@testdb$# v_out1 int; pg12@testdb$# v_out2 text; pg12@testdb$# begin pg12@testdb$# v_ret := func_out(1,v_out1,v_out2); pg12@testdb$# raise notice 'ret is : %d',v_ret; pg12@testdb$# end pg12@testdb$# $$ pg12@testdb-# ; ERROR: function func_out(integer, integer, text) does not exist LINE 1: SELECT func_out(1,v_out1,v_out2) ^ HINT: No function matches the given name and argument types. You might need to add explicit type casts. QUERY: SELECT func_out(1,v_out1,v_out2) CONTEXT: PL/pgSQL function inline_code_block line 7 at assignment [local:/data/run/pg12]:5120 pg12@testdb=#
提示沒有相應的函數,原因是PG會忽略OUT參數,把out參數去掉重新調用
[local:/data/run/pg12]:5120 pg12@testdb=# do pg12@testdb-# $$ pg12@testdb$# declare pg12@testdb$# v_ret record; pg12@testdb$# v_out1 int; pg12@testdb$# v_out2 text; pg12@testdb$# begin pg12@testdb$# v_ret := func_out(1); pg12@testdb$# raise notice 'ret is : %',v_ret; pg12@testdb$# end pg12@testdb$# $$; NOTICE: ret is : (1,1) DO [local:/data/run/pg12]:5120 pg12@testdb=# [local:/data/run/pg12]:5120 pg12@testdb=#
返回的是record,第一個值為1,第二個值為1
1.PG會忽略輸出參數,判斷一個函數是否是同一個函數,僅判斷輸入參數;
2.如存在OUT參數,PG函數無法返回結果,只能通過OUT參數返回。
感謝各位的閱讀,以上就是“Oracle與PostgreSQL的區別有哪些”的內容了,經過本文的學習后,相信大家對Oracle與PostgreSQL的區別有哪些這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創新互聯,小編將為大家推送更多相關知識點的文章,歡迎關注!
本文標題:Oracle與PostgreSQL的區別有哪些-創新互聯
轉載源于:http://m.newbst.com/article34/dpegpe.html
成都網站建設公司_創新互聯,為您提供手機網站建設、關鍵詞優化、Google、外貿建站、定制開發、標簽優化
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯