我想在 PostgreSQL 中创建一堆重复的模式。这些模式将具有相同的内容但名称不同。我想让命令在脚本中执行此操作,以便我可以在测试时删除和重建。我想从命令行安装模式:psql -f script.sql dbname
。
由于我创建了许多重复的模式,我认为 script.sql
中的循环将是执行此操作的最佳方式。我可以将循环迭代器变量与模式名称一起使用,以确保每个重复的模式都有不同的名称。
根据我的阅读,循环必须存在于函数中。如果是这样,我是否应该在 script.sql
中定义一个函数,然后在定义之后调用该函数?我担心的是这个实用函数最终会成为数据库的一部分。是这样吗?例如。您在脚本中定义的函数是否绑定(bind)为脚本创建的数据库的一部分?有没有更好的方法?
最佳答案
在脚本中你可以写一个anonymous code block使用 DO
命令,使用任何可用的语言。该 block 被执行一次,然后被丢弃。 PL/pgSQL 语言(默认语言)的 stub :
DO $$
DECLARE
-- Local variables go here
BEGIN
-- Your code goes here
END; $$ LANGUAGE plpgsql;
关于sql - 在 sql 脚本中循环以创建模式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28214625/