婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PostgreSQL function返回多行的操作

PostgreSQL function返回多行的操作

熱門標簽:海豐有多少商家沒有地圖標注 外呼調研系統 合肥公司外呼系統運營商 打電話智能電銷機器人授權 地圖標注和圖片名稱的區別 美容工作室地圖標注 辦公外呼電話系統 重慶自動外呼系統定制 漯河外呼電話系統

1. 建表

postgres=# create table tb1(id integer,name character varying);
CREATE TABLE
postgres=# 
postgres=# insert into tb1 select generate_series(1,5),'aa';
INSERT 0 5 

2. 返回單字段的多行(returns setof datatype)

不指定out參數,使用return next xx:

create or replace function func01()returns setof character varying as $$
declare
n character varying;
begin
 for i in 1..5 loop
 select name into n from tb1 where id=i;
 return next n;
 end loop;
end
$$ language plpgsql;

指定out參數,使用return next:

create or replace function func02(out character varying)returns setof character varying as $$
begin
 for i in 1..5 loop
 select name into $1from tb1 where id=i;
 return next;
 end loop;
end
$$ language plpgsql;

使用return query:

create or replace function func03()returns setof character varying as $$
begin
 for i in 1..5 loop
 return query(select name from tb1 where id=i);
 end loop;
end
$$language plpgsql;

3. 返回多列的多行(returns setog record)

不指定out參數,使用return next xx:

create or replace function func04()RETURNS SETOF RECORD as $$
declare
 r record;
begin
 for i in 1..5 loop
 select * into r from tb1 where id=i;
 return next r;
 end loop;
end;
$$language plpgsql;

在使用func04的時候注意,碰到問題列下:

問題一:

postgres=# select func04();
ERROR: set-valued function called in context that cannot accept a set
CONTEXT: PL/pgSQL function func04() line 7 at RETURN NEXT

解決:

If you call your set-returning function the wrong way (IOW the way you might normally call a function), you will get this error message: Set-valued function called in context that cannot accept a set. Incorrect: select sr_func(arg1, arg2, …); Correct: select * from sr_func(arg1, arg2, …);

問題二:

postgres=# select * from func04();
ERROR: a column definition list is required for functions returning "record"
LINE 1: select * from func04();

解決:

postgres=# select * from func04() as t(id integer,name character varying);
 id | name 
----+------
 1 | aa
 2 | aa
 3 | aa
 4 | aa
 5 | aa
(5 rows)

這個問題在func04如果指定out參數就不會有問題,如下func05所示:

指定out參數,使用return next:

create or replace function func05(out out_id integer,out out_name character varying)returns setof record as $$
declare
 r record;
begin
 for i in 1..5 loop
 select * into r from tb1 where id=i;
 out_id:=r.id;
 out_name:=r.name;
 return next;
 end loop;
end;
$$language plpgsql;
postgres=# select * from func05();
 id | name 
----+------
 1 | aa
 2 | aa
 3 | aa
 4 | aa
 5 | aa
(5 rows)

使用return query:

create or replace function func06()returns setof record as $$
begin
 for i in 1..5 loop
 return query(select id,name from tb1 where id=i);
 end loop;
end;
$$language plpgsql;
postgres=# select * from func06() as t(id integer,name character varying);
 id | name 
----+------
 1 | aa
 2 | aa
 3 | aa
 4 | aa
 5 | aa
(5 rows)

補充:Postgresql - plpgsql - 從Function中查詢并返回多行結果

通過plpgsql查詢表,并返回多行的結果。

關于創建實驗表插入數據這里就不說啦

返回查詢結果

mytest=# create or replace function test_0830_5() returns setof test
mytest-# as $$
mytest$# DECLARE
mytest$# r test%rowtype; -- 將
mytest$# BEGIN
mytest$# FOR r IN
mytest$# SELECT * FROM test WHERE id > 0
mytest$# LOOP
mytest$# RETURN NEXT r;
mytest$# END LOOP;
mytest$# RETURN;
mytest$# END
mytest$# $$ language plpgsql;
CREATE FUNCTION
 
mytest=# select test_0830_5(1);
test_0830_5
------------------------------------------
(2,abcabc,"2018-08-30 09:26:14.392187")
......
(11,abcabc,"2018-08-30 09:26:14.392187")
(10 rows)
 
mytest=# select * from test_0830_5();
id | col1 | col2
----+--------+----------------------------
2 | abcabc | 2018-08-30 09:26:14.392187
......
11 | abcabc | 2018-08-30 09:26:14.392187
(10 rows)

返回某列

mytest=# CREATE OR REPLACE FUNCTION test_0830_6(date) RETURNS SETOF integer AS $$
mytest$# BEGIN
mytest$# RETURN QUERY SELECT id
mytest$# FROM test
mytest$# WHERE col2 >= $1
mytest$# AND col2  ($1 + 1);
mytest$# IF NOT FOUND THEN
mytest$# RAISE EXCEPTION 'No id at %.', $1;
mytest$# END IF;
mytest$# RETURN;
mytest$# END
mytest$# $$
mytest-# LANGUAGE plpgsql;
CREATE FUNCTION
mytest=# select test_0830_6('2018-08-30');
test_0830_6
-------------
2
......
11
(10 rows)

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • Postgresql創建新增、刪除與修改觸發器的方法
  • PostgreSQL+Pgpool實現HA主備切換的操作
  • PostgreSQL時間線(timeline)和History File的用法
  • 基于postgresql行級鎖for update測試
  • 查看postgresql數據庫用戶系統權限、對象權限的方法
  • Postgresql鎖機制詳解(表鎖和行鎖)
  • postgres主備切換之文件觸發方式詳解

標簽:衡陽 錦州 來賓 株洲 珠海 蚌埠 晉城 烏海

巨人網絡通訊聲明:本文標題《PostgreSQL function返回多行的操作》,本文關鍵詞  PostgreSQL,function,返回,多,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PostgreSQL function返回多行的操作》相關的同類信息!
  • 本頁收集關于PostgreSQL function返回多行的操作的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 深州市| 门源| 辰溪县| 海晏县| 闽侯县| 当雄县| 大关县| 宜春市| 安福县| 富阳市| 广丰县| 噶尔县| 武平县| 安多县| 旺苍县| 土默特左旗| 蒙阴县| 满洲里市| 临颍县| 儋州市| 兰考县| 华安县| 兴国县| 吉水县| 武穴市| 建德市| 巍山| 陈巴尔虎旗| 菏泽市| 百色市| 大田县| 藁城市| 嘉兴市| 湖南省| 简阳市| 亚东县| 吉林省| 永嘉县| 股票| 和静县| 琼中|