作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 PostgreSQL 9.1 中,我需要将表名作为参数传递给我的函数以在游标中使用 - 然后调用该函数:
select myfunction('tableA');
或:
select myfunction('tableB')
我试过这个:
create or replace function myfunction(sid text)
returns integer as $BODY$
declare
bids cursor is select id from sid; --line 4
begin
for bid in bids loop
--some logic
end loop;
return 1;
end;
$BODY$
language plpgsql volatile;
我在第 4 行收到错误
。我明白了,不允许将表名作为函数参数传递给它允许休息的地方(选择、投影)。
是否有其他方法可以实现这一点?
最佳答案
在 SQL 命令中只能参数化值,不能参数化标识符或关键字。目前它仅适用于 SELECT
、INSERT
、UPDATE
和 DELETE
命令。详情:
您需要在 plpgsql 中使用 EXECUTE
的动态 SQL。
将其与 FOR
循环的隐式游标相结合,后者通常比显式游标更简单、更快。 Instructions in the manual.
我还建议使用 regclass
参数来安全地传递有效表名。
CREATE OR REPLACE FUNCTION myfunction(_tbl regclass)
RETURNS int AS
$func$
DECLARE
bid integer; -- appropriate data type!
BEGIN
FOR bid IN EXECUTE
'SELECT id FROM ' || _tbl
LOOP
-- statements can use bid
RAISE NOTICE '%', bid;
END LOOP;
RETURN 1;
END
$func$ LANGUAGE plpgsql;
调用:
SELECT myfunction('tableA'); -- careful: case sensitive!
更多解释:
通常,有一个更快的基于集合的解决方案,根本不需要循环。
如果您确实需要游标,请声明一个未绑定(bind)游标并使用OPEN FOR EXECUTE
打开它。 :
CREATE OR REPLACE FUNCTION myfunction(_tbl text) -- could be regclass again
RETURNS int AS
$func$
DECLARE
_bids refcursor;
_rec record;
BEGIN
OPEN _bids FOR EXECUTE 'SELECT id FROM ' || quote_ident(_tbl); -- text must be escaped
LOOP
FETCH NEXT FROM _bids INTO _rec;
EXIT WHEN _rec IS NULL;
-- some logic
RAISE NOTICE '%', _rec.id;
END LOOP;
RETURN 1;
END
$func$ LANGUAGE plpgsql;
同样的电话。这个密切相关的答案中的更多详细信息:
关于postgresql - 如何将游标的表名作为函数参数传递?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37966972/
我是一名优秀的程序员,十分优秀!