1

我正在使用 Postgresql 并有一个简单的函数,它将向客户端返回一个 refcursor:

CREATE OR REPLACE FUNCTION select_user(cur refcursor, m_id text)
RETURNS setof refcursor AS $$ 
BEGIN
    OPEN $1 FOR SELECT * FROM public.users WHERE id=m_id;
    RETURN NEXT $1;
END;
$$ LANGUAGE plpgsql; 

我可以这样获取数据:

SELECT select_user('cur','999999'); FETCH ALL in cur;

像这样返回 1 行:

username   email                id
999999     999999@somewhere.cm  999999 

但是现在的问题是,我使用 pl/proxy 和 Postgresql 在 pl/proxy 服务器中我写了这个函数:

CREATE OR REPLACE FUNCTION select_user(cur refcursor, m_type integer, m_hid text)
RETURNS setof refcursor AS $$ 
   CLUSTER 'sqlcluster';
   RUN ON select_db(m_hid);
$$ LANGUAGE plproxy;

从上面的函数它返回 refcursor,但我无法使用这个命令获取 refcursor:

SELECT select_user('cur','999999'); FETCH ALL in cur;

返回错误:

SQL error:

ERROR:  cursor "cur" does not exist

谁能解释一下有什么问题?

4

1 回答 1

1

PL/Proxy 函数在不同的数据库中运行,并且 refcursor 在那里无效。您将不得不重新设计那部分代码。

于 2013-09-10T17:54:57.960 回答