gpt4 book ai didi

ruby-on-rails - 在 ActiveRecord 查询中返回另一个模型的结果

转载 作者:行者123 更新时间:2023-12-05 06:41:17 25 4
gpt4 key购买 nike

假设我在两个表之间有一个简单的一对多关系

class Table < ActiveRecord:Base
has_may :legs
end

class Leg < ActiveRecord:Base
belongs_to :table
end

当我运行以下查询时,它返回 Table 的列表模型对象。

Table.joins(:legs).where("legs.type = 'short'")
# => [<Table id: 1>, <Table id: 1>]

因为 Table可以有很多 legs满足上述查询条件,我有时会收到重复的 Table我的结果中的实例。

如果能够查询 Table 会容易得多(尤其是在比这复杂得多的情况下)但让它返回 Leg 的结果集对象

Table.joins(:legs).where("legs.type = 'short'")
# => [<Leg id: 1>, <Leg id: 2>]

这可能吗?

谢谢!

编辑:明确地说,我知道我可以通过 map每个对象都得到我想要的结果。但这在一对多关系中变得棘手。所以我正在寻找一种更“原生”的 ActiveRecord 方式来做到这一点

编辑 2:我也知道我可以直接查询 Leg - 这不是问题。问题的核心是“是否可以查询 Table 但返回 Leg 对象的列表?”。这个上下文超出了问题的范围,但是当一个模型映射到许多其他模型类型时,我在查询多态关联时遇到了它的需要。

最佳答案

这是一个奇怪的解决方法,但您可以这样做:

Leg.find_by_sql(Table.joins(:legs).where("legs.type = 'short'").select("DISTINCT legs.*").to_sql)

将核心查询转换为原始 sql,然后在腿模型上运行该原始 sql。只要结果有查询模型的所有字段即可。

关于ruby-on-rails - 在 ActiveRecord 查询中返回另一个模型的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40855569/

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