优化ActiveRecord查询

时间:2012-08-29 12:48:59

标签: ruby-on-rails activerecord

我在数据库中有2个表:汽车和域名。 一辆车可以有很多域,一个域可以有很多车。

在我的项目中有三个模型:

class Car < ActiveRecord::Base

  has_many :cars_domains
  has_many :domains, :through => :cars_domains

...

class Domain < ActiveRecord::Base

    has_many :cars_domains
    has_many :cars, :through => :cars_domains
...

class CarsDomain < ActiveRecord::Base
  belongs_to :car
  belongs_to :domain
end

我想看看没有域名的汽车:

@cars = Car.find(:all, :conditions => ['id not in(select car_id from cars_domains where domain_id = ?)', params[:domain_id]])

这是有效的,但我认为这很困难。也许可以做得更简单?

1 个答案:

答案 0 :(得分:1)

在我创建的快速应用中尝试了这个:

domain = Domain.find(params[:domain_id])
Car.includes(:cars_domain).where('cars_domain.domain_id <> ?', domain.id)

我查询域对象的原因是因为我总是厌倦了将请求头中的值作为SQL中的查询参数传递。