pgsql返回表错误:列引用不明确

rya*_*ata 6 postgresql return function plpgsql

我一直得到这个错误:列引用"人"是模棱两可的.

我需要返回一个TABLE(人整数).当我使用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;
Run Code Online (Sandbox Code Playgroud)

Phi*_*ing 21

不明确的列引用是由于有多个同名列可用.在这种情况下,我想这是一个返回一张桌子的怪癖.尝试将查询更改为:

SELECT egroupdata.person FROM egroupdata WHERE egroup IN (SELECT recurse(_init_id))
Run Code Online (Sandbox Code Playgroud)

这将消除列引用的歧义.

  • 谢谢你说.如果答案是正确的,请"接受"答案 (9认同)