我正在做我的第一个 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? }
此范围不会引发任何错误,但搜索结果为零。