我不断收到此错误:列引用“人”不明确。
我需要返回一个表(个人整数)。当我使用 SETOF 整数时它工作正常,但在这种情况下它不起作用。我的另一个函数 recurse() 完美地返回一组整数。
CREATE OR REPLACE FUNCTION try(_group text) RETURNS TABLE (person integer) AS $$
DECLARE
_init_id integer;
_record integer;
BEGIN
SELECT id INTO _init_id FROM egroups WHERE name = _group;
FOR _record in SELECT person FROM egroupdata WHERE egroup IN (SELECT recurse(_init_id))
LOOP
RETURN NEXT;
END LOOP;
END;
$$ language plpgsql stable;
不明确的列引用是由于存在多个同名的列造成的。在这种情况下,我猜这是返回表格的一个怪癖。尝试将查询更改为:
SELECT egroupdata.person FROM egroupdata WHERE egroup IN (SELECT recurse(_init_id))
这将消除列引用的歧义。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)