gpt4 book ai didi

postgresql - 如何将游标的表名作为函数参数传递?

转载 作者:行者123 更新时间:2023-11-29 12:43:24 26 4
gpt4 key购买 nike

在 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 命令中只能参数化值,不能参数化标识符或关键字。目前它仅适用于 SELECTINSERTUPDATEDELETE 命令。详情:

您需要在 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com