Myšlenka získat shodu všech hodnot v IN
klauzule musíte udělat toto:
tag_ids = [1, 2, 3, 4]
Post.joins(:tags).where('tags.id IN (?)', tags_ids).group("posts.id")
.having("COUNT(posts.id) >= ?", tag_ids.length)
Doufám, že vám to pomůže.