has_many :through when join table doesn't contain FK to both tables

Posted by seth.vargo on Stack Overflow See other posts from Stack Overflow or by seth.vargo
Published on 2011-01-14T02:40:55Z Indexed on 2011/01/14 2:54 UTC
Read the original article Hit count: 320

I have a structure that isn't really a has_many :through example, but I'd like it to behave like one:

# user.rb
belongs_to :blog
has_many :posts

# post.rb
belongs_to :user

# blog.rb
has_many :users
has_many :posts, :through => :users  # this obviously doesn't work becase
                                     # both FKs aren't in the blogs table

I want to get ALL posts for a blog in an array. I'm aware that I can do this with Ruby using each or getting fancy with collect, but I'd like to let SQL do the work.

Can someone explain how I can set up my models in a way that lets me call @blog.posts using SQL, not Ruby?

Edit:

I know in SQL I can write something like:

SELECT * FROM posts WHERE posts.user_id IN (
  SELECT users.id FROM users WHERE users.blog_id = 7
)

which obviously shows two queries are needed. I don't think this is possible with a join, but I'm not totally sure. It's obvious that a subquery is needed, but how do I get rails to build that subquery with ARel instead of having to return and use Ruby to loop and collect and such?

© Stack Overflow or respective owner

Related posts about ruby-on-rails

Related posts about activerecord