我需要每天动态创建一个表。目前,这是我的工作解决方案:
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;
但是,您可以看到我必须为{I}尝试创建的表提及format
命令添加参数。添加一些约束,索引等,这变得站不住脚。
如何通过设置表名变量一次然后反复使用它来完成此操作?理想情况下,我希望解决方案可以在PGAdmin查询窗口中执行。但话说回来,这将最终存储在sql文件中并从脚本执行。
我在搜索解决方案时尝试了我已经看过的/set
这个问题,但我总是以斜杠开头出现语法错误。
答案 0 :(得分:2)
使用位置字段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')
);