是的,可以做到:
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,它在会话期间(默认情况下)存在,而不仅仅是事务。桌子用途广泛得多。游标对大型结果集更有意义。