我需要使用函数get_data(_id)返回"select * from table1 t1 join table2 t2 on t1.id = t2.t2id where t1.id = _id"
。
字体解决方案:https://stackoverflow.com/a/11751557但是有一个表的结果,我不能理解这是可能添加连接到这个查询从多个表获得结果吗?
我试着:
CREATE OR REPLACE FUNCTION get_data_test_2(_tbl_type anyelement,_tbl_type_2 anyelement, _id int)
RETURNS SETOF anyelement
LANGUAGE plpgsql AS
$func$
BEGIN
RETURN QUERY EXECUTE format('
SELECT *
FROM %s as s1 -- pg_typeof returns regtype, quoted automatically
left join %s as s2 on s1.id = s2.t1id
WHERE id = s1.'||_id||''
, pg_typeof(_tbl_type))
USING _id;
END
$func$;
但很明显它不起作用乌利希期刊指南我需要从连接表中动态获取所有列,而不需要设置显式列名的主要问题。
你可以试试:
CREATE OR REPLACE FUNCTION get_data_test_2(_tbl_type anyelement,_tbl_type_2 anyelement, _id int)
RETURNS SETOF record
LANGUAGE plpgsql AS
$func$
BEGIN
RETURN QUERY EXECUTE format('
SELECT *
FROM %s as s1
left join %s as s2 on s1.id = s2.t1id
WHERE id = s1.'||_id
, pg_typeof(_tbl_type)
, pg_typeof(_tb2_type))
USING _id;
END
$func$;