如何在 has_many 关系中搜索?

Posted

技术标签:

【中文标题】如何在 has_many 关系中搜索?【英文标题】:How to search back in a has_many relationship? 【发布时间】:2013-03-28 07:00:43 【问题描述】:

例如,一位教授有很多约会。所以我们将有一个教授表和一个约会表。在后者中,每个条目都有一个外键指向教授表中的条目,这是 Rails 中典型的 has_many 关系。

我的问题是,如果我想查询某个特定教授的所有约会,该怎么办?由于没有从教授到约会的反向指针,这意味着我必须查找整个约会表并检查仅针对这一位教授的那些。我知道这种方式有效,但效率似乎很差。所以任何人都可以给我一个更好的反向搜索解决方案(我不知道你怎么称呼它,所以我在这里编造术语)在 has_many 关系中。

【问题讨论】:

【参考方案1】:

鉴于此代码:

class Professor < ActiveRecord::Base
  has_many :appointments
end

class Appointment < ActiveRecord::Base
  belongs_to :professor
end

您可以使用关联来查询数据库,如下所示:

professor = Professor.find(1)
appointments = professor.appointments

这将仅检索属于特定教授的约会。此代码不会将整个约会表加载到内存中。它正在构建一个只选择所需数据子集的查询。

【讨论】:

不要忘记使用实例变量来查看视图中的约会 :)

以上是关于如何在 has_many 关系中搜索?的主要内容,如果未能解决你的问题,请参考以下文章

如何在 has_many 关系中急切加载最新的对象?

如何在 Ruby on Rails 6 中正确应用 has_many 关系和 order by

如何避免 has_many :through 关系中的重复?

如何实现has_many:通过与Mongoid和mongodb的关系?

如何修改依赖::destroy 查询 has_many 关系

如何使用has_many通过关系缩短三重连接ActiveRecord查询?