【发布时间】:2015-04-05 08:05:54
【问题描述】:
我是 plpgsql 的初学者,我一直在编写一个函数。 我需要一个执行以下操作的函数:
给出一个表,该表中的 id_field 和该表中的另一个字段:
原始表
id_field field_traspose
--------- --------------
1 A
1 B
1 C
2 A
3 F
3 X
结果
id_field field_traspose
--------- --------------
1 A, B, C
2 A
3 F, X
我的尝试:
CREATE OR REPLACE FUNCTION traspose(mytable character varying, id_field character varying, field_traspose character varying)
RETURNS setof RECORD AS
$BODY$
DECLARE
r record;
result record;
BEGIN
FOR r IN EXECUTE 'SELECT '||id_field||','||field_traspose||' from '||mytable LOOP
-- Here should go the logic that joins every field_traspose for a same id_field and
--returns the record as one of the returning records (can be many different id_fields)
RETURN NEXT result;
END LOOP;
RETURN;
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100;
我被困在这一点上。 问候,
【问题讨论】:
标签: postgresql function user-defined-functions plpgsql