开发者

Is there an ActiveRecord equivalent to using a nested subquery i.e. ... where NOT IN(select...)?

开发者 https://www.devze.com 2022-12-26 16:37 出处:网络
I have 3 models: Category, Account, and SubAccount The relations are: Accounts has_many :sub_accounts

I have 3 models: Category, Account, and SubAccount

The relations are:

Accounts has_many :sub_accounts

Categories has_many :sub_accounts

I wanted to get a list of all Categories that are not used by a given account. My method in the Category model currently l开发者_JAVA技巧ooks like:

class Category < ActiveRecord::Base  
  def self.not_used_by(account)
      Category.find_by_sql("select * from categories where id not in(select category_id from sub_accounts where account_id = #{account.id})")
  end
end

My question is, is there a cleaner alternative than using SQL?

NB. I am currently using Rails 3(beta)


You could move the method to the account model and use more of ActiveRecord by doing something like:

class Account < ActiveRecord::Base  
  def unused_categories
    Category.where("id NOT IN (?)", sub_accounts.map(&:category_id))
  end
end

Then you could do something like:

Account.first.unused_categories


AR does not do this out of the box. You may also want to check the excellent SearchLogic gem for a programatic approach.

search = Category.search
search.id_not_in sub_accounts.map(&:category_id)
search.name_equals "auto"
search. ..# other conditions
search.all


Try MetaWhere. http://metautonomo.us/projects/metawhere

You'll need my fork of Arel installed until the changes get merged (soon!) but with it installed you can do something like:

Category.where(:id.not_in => sub_accounts.map(&:category_id))

0

精彩评论

暂无评论...
验证码 换一张
取 消