小编Mus*_*ush的帖子

Rails:查找关系具有指定属性的所有用户

我有三个模型:

class User < ActiveRecord::Base
  has_many :rosterplayers
  has_many :rosters, -> { uniq } ,  :through => :rosterplayers
end

class Roster < ActiveRecord::Base
  has_many :rosterplayers
  has_many :users, -> { uniq }, through: :rosterplayers
end

class Rosterplayer < ActiveRecord::Base
  belongs_to :roster
  belongs_to :user
  validates :user_id, :uniqueness => { :scope => :roster_id }
end
Run Code Online (Sandbox Code Playgroud)

Rosterplayer 表包含三列:user_id,roster_id,pending(布尔值)

问题:给定一个名册,我将如何检索当前待处理的所有用户?

尝试:我的第一次尝试是遍历名册中的所有用户:

@team.rosters[0].users.each do |u|
  Rosterplayer.find_by(roster_id: rosters[0].id, user_id: u.id, pending: true)
end
Run Code Online (Sandbox Code Playgroud)

但我觉得有更好的方法来做到这一点。

ruby-on-rails

3
推荐指数
1
解决办法
418
查看次数

标签 统计

ruby-on-rails ×1