ruby-on-rails - 从多租户应用程序中的两个或多个模式访问数据
问题描述
我们正在将公寓 gem用于多租户应用程序。对于每个帐户,都会有一个单独的架构被维护。根据账户的子域,我们列出每个账户中的数据。
在我们的新要求中,有一个类似于超级帐户的东西,可以查看所有帐户数据。例如,如果在用户列表页面中选择了账户1和账户2,则账户1和账户2的用户应该结合搜索提供一起查看。有没有办法在公寓中组合多个模式数据?或任何其他替代品
解决方案
我能想到的最简单的方法是跨相关模式执行联合查询。因此,如果您有模式account_1
和account_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)
推荐阅读
- java - 如何以最佳方式创建用于内存管理的 java 对象?
- c# - UWP 中的 System.String
- django - 无法加载 Django WSGI 应用程序
- r - Blogdown 无法在我的 Rmd 文档中呈现 tikz 块
- python - 无法遍历 Django 模板中的查询集
- ionic-framework - 如何在 Ionic 的特定页面上显示后退按钮
- swift - 我如何在 Swift 4 中使用陀螺仪来获得 Yaw?
- angular - @angular/core/core 没有导出成员 'StaticProvider'
- git - 从 Kubernetes 机密中获取凭据时的 go-git 基本身份验证问题
- android - junit 可以在其沙箱之外写入磁盘吗