gpt4 book ai didi

ruby-on-rails - Postgres + Rails - 将所有表从一个模式迁移到另一个模式的正确方法

转载 作者:行者123 更新时间:2023-11-29 11:47:31 25 4
gpt4 key购买 nike

我目前有一个 Rails 应用程序,它使用 Postgres 并将其所有表存储在默认的 public 模式下。

我正在建立一个更多的 Multi-Tenancy 架构,所以我想将所有这些表从 public 移动到另一个架构 foo

我正在使用以下 Rails 迁移来完成这个 -

class MovePublicToFoo < ActiveRecord::Migration
def up
[
"ALTER SCHEMA public RENAME TO foo;",
"CREATE SCHEMA public;"
].each { |s| ActiveRecord::Base.connection.execute(s) }
end

def down
[
"DROP SCHEMA public;",
"ALTER SCHEMA foo RENAME TO public;"
].each { |s| ActiveRecord::Base.connection.execute(s) }
end
end

这是在 Postgres 中解决这个问题的正确方法吗?

我不知道盲目移动默认模式的危险是什么,以及这可能对 search_path 产生什么影响(我也不太确定那会做什么)

谢谢!

最佳答案

这种迁移的影响超出了 Rails 的范围。这取决于 Rails 用于连接数据库的数据库用户(postgres 角色)以及该用户在公共(public)模式中拥有/缺少的权限。您需要确保在重命名模式以及数据库所有权后保留特权。我没有测试过这种迁移,但我认为从 Rails 的应用程序数据库用户的角度来看,它应该可以正常工作。但是,如果您有其他依赖公共(public)模式的 pg 用户,您可能会干扰他们的连接和权限。

重命名 postgres 模式,尤其是默认模式,可能不应该在 Rails 迁移中完成,除非特定的 postgres 安装专用于 Rails 应用程序。

尽管有我的意见,但 postgres 的文档并未提出任何关于您的迁移应该关注的问题:http://www.postgresql.org/docs/9.4/static/sql-alterschema.html

关于ruby-on-rails - Postgres + Rails - 将所有表从一个模式迁移到另一个模式的正确方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33116241/

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