gpt4 book ai didi

sql - 如何一次将升级脚本应用于多个 PostgreSQL 模式?

转载 作者:搜寻专家 更新时间:2023-10-30 22:34:19 25 4
gpt4 key购买 nike

我正在尝试在 PostgreSQL 上使用单数据库/多模式创建 Multi-Tenancy SaaS 应用程序。我想知道是否有一种方法可以在 PostgreSQL 中使用单个命令升级多个模式。

我正在寻找这样的东西:

CREATE TABLE tenants_*.users (id VARCHAR(255) PRIMARY KEY NOT NULL);

注意:我也在使用 Liquibase 进行模式迁移,但发现无法使用 Liquibase 进行多模式升级。

任何帮助将不胜感激。谢谢。

最佳答案

在纯 SQL 中没有内置的方法来执行此操作,但您可以使用 plpgsql:

DO
$$
DECLARE
schemaname name;
BEGIN
FOR schemaname IN SELECT nspname FROM pg_namespace WHERE nspname LIKE 'tenants_%' LOOP
EXECUTE format('CREATE TABLE %I.users (id text PRIMARY KEY);', schemaname);
END LOOP;
END;
$$ LANGUAGE plpgsql;

作为旁注,您可能不想要具有字符限制的 varchar 列,因为它在 PostgreSQL 中没有实际好处。只使用文本,除非您出于某种原因真的希望您的值被截断为 255 个字符。

关于sql - 如何一次将升级脚本应用于多个 PostgreSQL 模式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39375750/

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