我是一名铁杆新手,我在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) }
答案 0 :(得分:12)
试试这个。它更加优化。
scope :by_role, ->(role) { joins(:roles).where(roles: { name: role }) }