例如,一位教授有很多约会。所以我们将有一个教授表和一个约会表。在后者中,每个条目都有一个外键指向教授表中的条目,这是 Rails 中典型的 has_many 关系。
我的问题是,如果我想查询特定教授的所有约会怎么办?由于没有从教授到约会的反向指针,这意味着我必须查找整个约会表并检查仅针对这一位教授的那些。我知道这种方式有效,但效率似乎很差。因此,任何人都可以在 has_many 关系中给我一个更好的反向搜索解决方案(我不知道你怎么称呼它,所以我在这里编造术语)。
例如,一位教授有很多约会。所以我们将有一个教授表和一个约会表。在后者中,每个条目都有一个外键指向教授表中的条目,这是 Rails 中典型的 has_many 关系。
我的问题是,如果我想查询特定教授的所有约会怎么办?由于没有从教授到约会的反向指针,这意味着我必须查找整个约会表并检查仅针对这一位教授的那些。我知道这种方式有效,但效率似乎很差。因此,任何人都可以在 has_many 关系中给我一个更好的反向搜索解决方案(我不知道你怎么称呼它,所以我在这里编造术语)。
鉴于此代码:
class Professor < ActiveRecord::Base
has_many :appointments
end
class Appointment < ActiveRecord::Base
belongs_to :professor
end
您可以使用关联来查询数据库,如下所示:
professor = Professor.find(1)
appointments = professor.appointments
这将仅检索属于特定教授的约会。此代码不会将整个约会表加载到内存中。它正在构建一个仅选择所需数据子集的查询。