如何搜索has_many关系?

时间:2013-03-28 07:00:43

标签: sql ruby-on-rails database

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

我的问题是,如果我想查询特定教授的所有约会怎么办?由于没有从教授到约会的指针,这意味着我必须查看整个约会表,并查看仅适用于这一位教授的那些。我知道这种方式有效,但效率似乎很糟糕。因此,任何人都可以在has_many关系中为我提供更好的反向搜索解决方案(我不知道你在说什么,所以我在这里编写术语)。

1 个答案:

答案 0 :(得分:2)

鉴于此代码:

class Professor < ActiveRecord::Base
  has_many :appointments
end

class Appointment < ActiveRecord::Base
  belongs_to :professor
end

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

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

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