sql - 在 sql 脚本中循环以创建模式

标签 sql postgresql

我想在 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/

相关文章:

php - 获取具有相同行 ID 的列值

sql - 将 IN 子句与存储过程一起使用时,Firebird 查询花费的时间太长

用于从数据库生成 Postgres SQL 脚本的 Java 库

sql - "column must appear in the GROUP BY clause or be used in an aggregate function"

sql - 在 PostgreSQL 和 Oracle 中,什么时候 NULL 和空字符串被同等对待?

sql - 共享外部表的两个查询

mysql - 为什么此查询返回空行?

sql - 我如何在我的 SQL Server Profiler 上关闭来自 "Report Server"的行?

c# - 使用此查询时出现 SQL 语法错误

python - 如何在 SQLAlchemy 上使用 GIN 创建 jsonb 索引?