游标可以在 PL/pgSQL 中保存变量吗?

Posted

技术标签:

【中文标题】游标可以在 PL/pgSQL 中保存变量吗?【英文标题】:Can a cursor hold variables in PL/pgSQL? 【发布时间】:2014-04-22 21:27:01 【问题描述】:

我知道游标可以封装一个查询,但是它也可以指向一个变量值还是多个?

例如:

declare
my cursor refcursor;
var_x varchar;
begin
        var_x := (select x from table where id = 7);
        open mycursor for select(var_x);
end;

这在 PL/pgSQL 中可能吗?

【问题讨论】:

【参考方案1】:

是的,可以做到:

CREATE OR REPLACE FUNCTION f_value_cursor(_curs refcursor, _id1 int, _id2 int)
  RETURNS TABLE (col1 int, col2 text) AS
$func$
DECLARE
    var_x text := (SELECT t.col2 FROM tbl t WHERE t.tbl_id = _id1);
BEGIN

OPEN _curs FOR SELECT var_x;

RETURN QUERY
SELECT t.col1, t.col2
FROM   tbl t
WHERE  t.tbl_id >= _id2;

END
$func$  LANGUAGE plpgsql;

游标适用于返回行的任何查询——即使它像示例中那样返回单个常量。

使用未绑定的游标变量作为参数,您可以将游标的名称传递给函数。

我让函数同时返回一个表,因为这似乎是你在最后几个问题中所追求的。

正如in my previous answer 所述,您必须在同一事务中从游标中获取值:

BEGIN;
SELECT * FROM f_value_cursor('mycursor', 1, 2);
FETCH ALL FROM mycursor;
ROLLBACK; -- or COMMIT

SQL Fiddle.

作为记录:请考虑使用temporary table,它在会话期间(默认情况下)存在,而不仅仅是事务。桌子用途广泛得多。游标对大型结果集更有意义。

【讨论】:

以上是关于游标可以在 PL/pgSQL 中保存变量吗?的主要内容,如果未能解决你的问题,请参考以下文章

PL/pgSQL 代码的问题

在 PL/pgSQL 函数中使用变量

关于 Pl/pgsql 中游标的一些错误

使用 PL/pgSQL 将查询结果存储在变量中

它可以引用 PL/pgSQL 变量或表列

在 PL/pgSQL 中实现游标功能作为分页