如何在 PostgreSQL 查询中设置和使用变量
How to set and use a variable in a PostgreSQL Query
我需要每天动态创建一个 table。目前,这是我的工作解决方案:
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;
但是,您可以看到我必须如何为每次提及我尝试创建的 table 命令添加一个参数到 format
命令。添加一些约束、索引等,这就变得站不住脚了。
如何通过设置一次 table 名称变量然后一遍又一遍地使用它来完成此操作?理想情况下,我希望解决方案在 PGAdmin 查询 window 中执行 table。然而,话虽如此,这最终将存储在 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')
);
我需要每天动态创建一个 table。目前,这是我的工作解决方案:
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;
但是,您可以看到我必须如何为每次提及我尝试创建的 table 命令添加一个参数到 format
命令。添加一些约束、索引等,这就变得站不住脚了。
如何通过设置一次 table 名称变量然后一遍又一遍地使用它来完成此操作?理想情况下,我希望解决方案在 PGAdmin 查询 window 中执行 table。然而,话虽如此,这最终将存储在 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')
);