Rails HABTM 协会的 4 个范围

Rails 4 scope on HABTM association

我是一个 rails 新手,我在 HABTM 协会上创建了一个范围,但我仍然认为它看起来不自然,不优雅,所以我认为必须有更好的方法来做到这一点。如果有更好的方法,谁能告诉我?我看过其他帖子,人们有同样的问题 (Scope for Self-joining HABTM Association) 但没有答案...

class User < ActiveRecord::Base
  has_and_belongs_to_many :roles, :join_table => :users_roles
end

class Role < ActiveRecord::Base
  has_and_belongs_to_many :users, :join_table => :users_roles
end

scope :by_role, lambda { |role_name| joins('join users_roles on users.id = users_roles.user_id').
                                    joins('join roles on users_roles.role_id = roles.id').
                                    where('roles.name = ?', role_name) }

试试这个。它更优化。

 scope :by_role,  ->(role) { joins(:roles).where(roles: { name: role }) }