0

我正在做我的第一个 Rails 项目,我一直试图让我的两个模型一起工作。这是我的模型:

class Ecn < ActiveRecord::Base
  has_many :revisions, :dependent => :destroy
  has_many :drawings, through: :revisions
  accepts_nested_attributes_for :revisions, :reject_if => lambda { |attrs| attrs.all? { |key, value| value.blank? }}, :allow_destroy => true
  belongs_to :user

class Drawing < ActiveRecord::Base
  has_many :revisions

class Revision < ActiveRecord::Base
  belongs_to :drawing, foreign_key: :drawing_number
  belongs_to :ecn

我想要实现的是搜索使用修订foreign_key :drawing_number 的Ecns。当我创建一个 Ecn 时,我向 Ecn 添加了多个修订,其中有一个字段:drawing_number,它是 Drawings 的一个属性。我有一个 Ecn 搜索表单,它有多个要搜索的字段,其中之一是:drawing_number。我希望查询找到包含给定 :drawing_number 的所有修订,并找到包含这些修订的 Ecn。

我的 Ecn 模型中的范围如下所示:

scope :by_drawing_number, lambda { |drawing_number| Ecn.joins(:drawings).where("drawings.drawing_number LIKE ?",  "%#{drawing_number}%") unless drawing_number.nil? }

此范围不会引发任何错误,但搜索结果为零。

4

1 回答 1

1

以下应该是可能的:

scope :by_drawing_number, lambda { |drawing_number| Revision.where("drawing_number LIKE ?", "%#{drawing_number}%").map(&:ecn)

这将返回一个 Ecns 的集合。

于 2013-09-21T16:48:40.400 回答