首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rails活动记录全连接

Rails活动记录全连接
EN

Stack Overflow用户
提问于 2017-07-20 18:28:07
回答 1查看 2.6K关注 0票数 1

我有三张桌子:

代码语言:javascript
复制
DataRow (id, user_id)
DataPoint (id, data_row_id, data_type_id)
DataType (id, name, weight)

我成立了以下协会:

代码语言:javascript
复制
data_row.rb
has_many :data_points

data_point.rb
belongs_to :data_row
belongs_to :data_type

在我看来,我希望为每个DataType显示一个列的表。我的问题是,并非每个DataRow都包含针对每个DataType的DataPoint。

如果我这样做,我将只得到存在于该DataPoints中的DataRow

代码语言:javascript
复制
@rows = DataRow.includes(:data_points).where(user_id: params[:id])

是否有一种方法可以为每个用户返回一个DataPoint给每个DataRow的每个DataType,这样我就可以简单地遍历返回的DataRows了吗?DataType的“权重”列是显示顺序。

提前感谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-07-21 08:21:21

在您的模型中添加以下内容:

data_row.rb

代码语言:javascript
复制
  has_many :data_points
  has_many :data_types, through: :data_points

data_point.rb

代码语言:javascript
复制
belongs_to :data_row
belongs_to :data_type

data_type.rb

代码语言:javascript
复制
has_many :data_points
has_many :data_rows, through: :data_points

您可以做right joins表。

代码语言:javascript
复制
DataRow.select('data_rows.*, data_types.*, data_points.*')
       .joins("RIGHT JOIN data_points ON data_points.data_row_id = data_rows.id
               RIGHT JOIN data_types ON data_types.id = data_points.data_type_id")

希望这能帮到你。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45222585

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档