我想测试 Postgres 函数的结果(不可能更改函数)。
该函数接收 REFCURSOR 和其他一些东西作为参数,并返回相同的 RECURSOR。
get_function_that_returns_cursor(ret, 4100, 'SOMETHING', 123465)
现在我想在 Postgres 中创建一个小测试来获得这个 FUNCTION 的结果。类似于下面的代码(这是我的方法,但它不起作用):
DO $$ DECLARE
ret REFCURSOR;
row_to_read table_it_will_return%ROWTYPE ;
BEGIN
PERFORM get_function_that_returns_cursor(ret, 4100, 'SOMETHING', 123465);
-- OR SELECT get_function_that_returns_cursor(ret, 4100, 'SOMETHING', 123465) INTO ret
FOR row_to_read IN SELECT * FROM ret LOOP
-- (...)
RAISE NOTICE 'Row read...';
END LOOP;
CLOSE ret;
END $$;
关于如何让它工作的任何建议?可用于测试此类函数的通用解决方案(获取游标并返回游标?
如果我们不知道返回的行类型,我们怎么能做到呢?