- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
在我的 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/
最近在造轮子,从 0 到 1 的那种,就差前台的界面了,大家可以耐心耐心耐心期待一下。其中需要设计一些数据库表,可以通过 Navicat 这种图形化管理工具直接开搞,也可以通过一些数据库设计工具来搞,
本文已经收录到Github仓库,该仓库包含 计算机基础、Java基础、多线程、JVM、数据库、Redis、Spring、Mybatis、SpringMVC、SpringBoot、分布式、微服务、设
干燥路径“/A”和“/B”的解析参数的“Angular”方式是什么?在我的 $routeProvider 中,我为这些场景调用完全相同的解析函数,并且不知道避免在 AngularJS 框架中重复代码的
我确信有一种方法可以 DRY 代码。 changeColor() 所做的只是改变父组件的背景颜色。 import { Play } from "./play"; import { Hello } fr
我在 Node v6.3.0 中的 api 上运行以下代码,该 api 运行两个单独的 Promise,具体取决于 POST 请求中是否存在参数的条件。 if (paramExists) {
在我的 Ruby on Rails 项目中,我有一个邮件程序,它基本上为给定用户准备系统中发生的事情的每日摘要。在邮件 Controller 中,我根据一些通用模式(在特定日期内、不是由该用户创作
我是一名优秀的程序员,十分优秀!