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 }) }
我是一个 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 }) }