Rails ActiveRecord Scope是另一个范围的"对立面",或者是"缺少"属性的用户

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或类似的范围,这是所有没有管理员角色的用户.

最简单的方法是什么?

Sim*_*tsa 6

如果您想要反向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)