【问题标题】:pgsql return table ERROR: column reference is ambiguouspgsql返回表错误:列引用不明确
【发布时间】:2012-05-31 19:36:54
【问题描述】:

我不断收到此错误:列引用“人”不明确。

我需要返回一个 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;

【问题讨论】:

标签: postgresql function return plpgsql


【解决方案1】:

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

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

这将消除列引用的歧义。

【讨论】:

  • 感谢您的发言。如果正确,请“接受”答案
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2021-05-04
  • 2015-01-07
  • 2018-07-02
  • 1970-01-01
  • 2018-01-26
  • 1970-01-01
  • 2015-12-14
相关资源
最近更新 更多