gpt4 book ai didi

ruby-on-rails - 干掉 Rails Active Record 查询条件

转载 作者:数据小太阳 更新时间:2023-10-29 09:02:10 26 4
gpt4 key购买 nike

在我的 Ruby on Rails 项目中,我有一个邮件程序,它基本上为给定用户准备系统中发生的事情的每日摘要。在邮件 Controller 中,我根据一些通用模式(在特定日期内、不是由该​​用户创作、未标记等)收集来自各种模型的所有相关记录,并且模型之间存在细微差别。

这里涉及六个模型(并且还在增加),其中大多数都有统一的列名称用于某些事情(比如发布日期,或者一个项目是否被管理员标记)。因此,进入查询的“where”大部分是相同的。条件略有不同,但至少有2、3个条件是完全一样的。我很容易假设模型之间可能存在更多相似条件,因为我们才刚刚开始该功能,还没有弄清楚数据的最终形状。

我基本上将“where”调用链接到每个模型。让我感到恼火的是 6 行代码彼此如此接近,跨越我的代码编辑器的右侧那么远,但又如此相似。我害怕这样的想法,即在某个时候我们将不得不改变其中一个“核心”条件,同时修改那么多行代码。

我想做的是将进入每个查询的一组核心条件移动到某种 Proc 或其他什么,然后像范围一样简单地在每个模型上调用它,然后继续 'where' 链与特定于模型的条件。很像每个模型上的 scope

我正在纠结的是如何做到这一点,同时将代码保存在邮件程序中。我当然知道我可以在关注点内声明一个复杂的范围,然后将其混合到我的模型中并启动每个具有该范围的查询。然而,这种逻辑将从邮件程序转移到模型关注的未知领域,而且它会使每个模型复杂化,其范围目前只需要一个巨大系统中的一个小邮件程序。此外,对于某些查询,查询需要一组来自用户模型的详细信息,我不希望我的每个模型都处理用户。

我喜欢在 Active Record 模型中通过 lambda 定义范围的方式(如 scope :pending, -> { where(approved: [nil, false]) }),并且正在寻找一种在模型类外部和我的邮件程序方法内部使用类似语法的方法(可能使用 tap 或类似的东西),但我还没有找到这种方法的任何好的例子。

那么,有没有可能实现呢?我能否在我的邮件程序方法中的某个变量中收集核心“where”调用并将它们应用于许多模型,同时仍然能够在之后继续 where 链?

最佳答案

Arel 的美妙之处在于,ActiveRecord 查询构建背后的技术是完全可组合的,使用普通的 ruby​​。

我是否理解你的问题,这就是你想要做的?

def add_on_something(arel_scope)
arel_scope.where("magic = true").where("something = 1")
end


add_on_something(User).where("more").order("whatever").limit(10)

add_on_something( Project.where("whatever") ).order("something")

只需普通的 ruby​​ 方法即可,您不需要特殊的 AR 功能。因为 AR 范围已经是可组合的。

关于ruby-on-rails - 干掉 Rails Active Record 查询条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32969492/

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