Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/postgresql/10.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Postgresql pgsql返回表错误:列引用不明确_Postgresql_Function_Return_Plpgsql - Fatal编程技术网

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

Postgresql pgsql返回表错误:列引用不明确,postgresql,function,return,plpgsql,Postgresql,Function,Return,Plpgsql,我经常遇到这样的错误:列引用“person”是不明确的 我需要返回一个表(person整数)。当我使用SETOF integer时,它工作得很好,但在本例中它不工作。我的另一个函数recurse()完美地返回一组整数 CREATE OR REPLACE FUNCTION try(_group text) RETURNS TABLE (person integer) AS $$ DECLARE _init_id integer; _record integer; BEGIN

我经常遇到这样的错误:列引用“person”是不明确的

我需要返回一个表(person整数)。当我使用SETOF integer时,它工作得很好,但在本例中它不工作。我的另一个函数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))
这将消除列引用的歧义。

谢谢您这么说。如果答案是正确的,请“接受”答案