ist*_*ses 8 activerecord scope named-scope ruby-on-rails-3
我有一个user.rb模型,我在其中定义了一个范围admins,即通过权限表具有admin角色的用户.
has_many :permissions
has_many :roles, :through => :permissions
Run Code Online (Sandbox Code Playgroud)
范围的工作方式如下:
scope :admins, joins(:permissions).merge(Permission.admin_permissions)
Run Code Online (Sandbox Code Playgroud)
我还想制作一个名为non-admins或类似的范围,这是所有没有管理员角色的用户.
最简单的方法是什么?
如果您想要反向SQL查询,则必须手动完成.没有内置的ActiveRecord解决方案.
scope :admins, joins(:permissions).merge(Permission.where("permissions.admin = true"))
scope :non_admins, joins(:permissions).merge(Permission.where("permissions.admin = false"))
Run Code Online (Sandbox Code Playgroud)
如果有很多范围或它们很复杂,请考虑用id排除它们:
User.where("id not in (?)", User.admins.pluck(:id))
# or if you are already using admin records
admins = User.admins
User.where("id not in (?)", admins.map(&:id))
Run Code Online (Sandbox Code Playgroud)
根据行数和原始查询的复杂程度,这可能比以前的方式更慢或更快.
Kri*_*ris -1
一种简单的方法,但对于很多用户来说效果不佳:
admin_user_ids = User.admins.map(&:id)
non_admin_users = User.all.reject { |u| admin_user_ids.include?(u.id) }
Run Code Online (Sandbox Code Playgroud)