首页 > 解决方案 > 从多租户应用程序中的两个或多个模式访问数据

问题描述

我们正在将公寓 gem用于多租户应用程序。对于每个帐户,都会有一个单独的架构被维护。根据账户的子域,我们列出每个账户中的数据。

在我们的新要求中,有一个类似于超级帐户的东西,可以查看所有帐户数据。例如,如果在用户列表页面中选择了账户1和账户2,则账户1和账户2的用户应该结合搜索提供一起查看。有没有办法在公寓中组合多个模式数据?或任何其他替代品

标签: ruby-on-railsmulti-tenantapartment-gem

解决方案


我能想到的最简单的方法是跨相关模式执行联合查询。因此,如果您有模式account_1account_2,您会执行类似SELECT * FROM account_1.users UNION SELECT * FROM account_2.users.

当然,您可以使这个动态化——因此,如果您将受影响的帐户作为params散列的一部分发送,您可能会得到如下内容:

accounts = Account.find(params[:account_ids])
# assuming the schema name is stored in the accounts.tenant_name column:
sql = accounts.map { |account| "SELECT * FROM #{account.tenant_name}.users" }.join(" UNION ")
users = User.find_by_sql(sql)

推荐阅读