gpt4 book ai didi

sql - 如何在 PostgreSQL 查询中设置和使用变量

转载 作者:行者123 更新时间:2023-11-29 14:19:30 25 4
gpt4 key购买 nike

我需要每天动态创建一个表。目前,这是我的工作解决方案:

DO
$$
BEGIN
EXECUTE format('

CREATE TABLE schema.%I (
id NUMERIC,
field1 TEXT,
field2 TEXT
)
WITH (
OIDS=FALSE
);

GRANT ALL ON TABLE schema.%I TO role1;
GRANT ALL ON TABLE schema.%I TO role2;',

'table_name_' || to_char(CURRENT_DATE,'YYYYMMDD'),
'table_name_' || to_char(CURRENT_DATE,'YYYYMMDD'),
'table_name_' || to_char(CURRENT_DATE,'YYYYMMDD')
);
END;
$$ LANGUAGE plpgsql;

但是,您可以看到我必须如何为每次提及我尝试创建的表时向 format 命令添加一个参数。添加一些约束、索引等,这就变得站不住脚了。

如何通过一次设置表名变量然后一遍又一遍地使用它来实现这一点?理想情况下,我希望解决方案可以在 PGAdmin 查询窗口中执行。然而,话虽这么说,这最终将存储在一个 sql 文件中并从脚本中执行。

我已经尝试了在搜索解决方案时看到的 /set 东西,但我总是以斜杠开头的语法错误结束。

最佳答案

使用位置字段n$

EXECUTE format('

CREATE TABLE schema.%1$I (
id NUMERIC,
field1 TEXT,
field2 TEXT
)
WITH (
OIDS=FALSE
);

GRANT ALL ON TABLE schema.%1$I TO role1;
GRANT ALL ON TABLE schema.%1$I TO role2;',

'table_name_' || to_char(CURRENT_DATE,'YYYYMMDD')
);

关于sql - 如何在 PostgreSQL 查询中设置和使用变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34516278/

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