gpt4 book ai didi

ruby-on-rails - 如何使用范围连接多个表

转载 作者:行者123 更新时间:2023-12-04 17:49:47 25 4
gpt4 key购买 nike

我是 ROR 的新手,我正在尝试了解范围。在我当前的实现中,我正在获取所有处理器并将其显示在 View 中。

class ProcessorsController
def index
@processors = Processor.all
end
end

我想修改它,以便我只能获得用户为管理员的处理器 .我的关系就是这样建立起来的。
class Processor
belongs_to :feed

#SCOPES (what I have done so far)
scope :feed, joins(:feed)
scope :groups, joins(:feed => :groups).join(:user).where(:admin => true)
end

class Feed < ActiveRecord::Base
has_and_belongs_to_many :groups
end

class Group < ActiveRecord::Base
belongs_to :user
end

class User < ActiveRecord::Base
has_many :groups
scope :admin, where(:admin => true)
end

我能够在我的 pry 动中做到这一点
pry(main)> Processor.find(63).feed.groups.first.user.admin?

PS:如果关系很复杂,有人可以提供一些好的资源,让我可以学习如何使用范围。

最佳答案

scope :with_admin, -> { joins(:feed => { :groups => :user }).where('users.admin' => true) }

至于资源,你有没有通过 official documentation on ActiveRecord joins ?

关于ruby-on-rails - 如何使用范围连接多个表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19553758/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com