名前はさまざまな原因で変わる可能性があると思いますが、それは問題ではありません。eval関数を使用します。
CREATE OR REPLACE FUNCTION eval(expression text) RETURNS text
AS
$body$
DECLARE
result text;
BEGIN
execute expression INTO RESULT;
RETURN result;
END;
$body$
language plpgsql
動的クロス集計を作成できます。
SELECT eval('SELECT row_to_json(q)
FROM (SELECT '||(SELECT string_agg(DISTINCT '"'||name||'"',',')
FROM roles)||'
FROM crosstab(''SELECT 1,name,array_agg(person)::text[]
FROM roles
GROUP BY name;
'') as ct(row_name int,'||(SELECT string_agg(DISTINCT '"'||name||'" text[]',',')
FROM roles)||')
)as q');
編集
派手でないアプローチ:
SELECT '{'||string_agg(temp,',')||'}'
FROM
(
SELECT '"'||name||'": ['||(string_agg(person,',')::text)||']' as temp FROM roles GROUP BY name
) as q