0

这是我的简化情况:

class Producer
  has_and_belongs_to_many :rules
end

class Rule
  has_and_belongs_to_many :producers
end

Rule恰好遵循 STI 结构。所以我有这个:

class Producer
  has_and_belongs_to_many :rules

  has_and_belongs_to_many :product_rules, join_table: :producers_rules,
    association_foreign_key: :rule_id

  has_and_belongs_to_many :fee_rules, join_table: :producers_rules
    association_foreign_key: :rule_id
end

class Rule
  has_and_belongs_to_many :producers
end

class ProductRule < Rule
end

class FeeRule < Rule
end

没什么大不了的,效果很好。所以现在我想创建一个只返回ProducersProductRules

与此等价的东西:

Producer.all.select{|x| x.product_rules.any? }

谁能指出一个快速的解决方案?

注意:我显然不想加载所有生产者并在之后选择它们,我只想直接加载正确的


更新

我正在使用 Rails 版本 2.3.15

4

1 回答 1

1

Producer的每个子类之间的每个关联Rule都将在连接表上创建一个单独的记录。您可以使用该事实并选择Producer在连接表上有任何记录指向它们的所有 s(注意选择正确的type):

在 Rails 2.x 中:

class Producer
  def self.with_some_product_rule
    scoped(conditions: <<-SQL)
      producers.id IN (
        SELECT producer_id FROM producers_rules
        INNER JOIN rules ON rules.id = producers_rules.rule_id
        WHERE rules.type = 'ProductRule'
      )
    SQL
  end
end
于 2014-03-12T23:37:25.287 回答