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

时间:2012-05-25 08:01:20

标签: postgresql function return 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;

2 个答案:

答案 0 :(得分:20)

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

SELECT egroupdata.person FROM egroupdata WHERE egroup IN (SELECT recurse(_init_id))

这将消除列引用的歧义。

答案 1 :(得分:-2)

当然,模糊列引用是由于多个表中存在具有相同名称的属性。但上面的反应并没有解释到底应该做些什么。我有查询:

select a.b, c.b from vsh_a a, vsh_b b where a.id = b.id

用表名替换第一个别名无济于事。现在怎么办?