HABTM关联的Rails 4范围

时间:2015-07-26 15:22:43

标签: ruby-on-rails scope has-and-belongs-to-many

我是一名铁杆新手,我在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) }

1 个答案:

答案 0 :(得分:12)

试试这个。它更加优化。

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