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

时间:2014-04-22 21:27:01

标签: database postgresql cursor plpgsql

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

例如:

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 个答案:

答案 0 :(得分:0)

,可以这样做:

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,它在会话期间(默认情况下)存在,而不仅仅是事务。表格更加通用。对于巨大的结果集,游标更有意义。

相关问题