gpt4 book ai didi

ruby - 覆盖 AR 订单范围

转载 作者:太空宇宙 更新时间:2023-11-03 16:54:52 24 4
gpt4 key购买 nike

我有一个项目模型和一个开发人员模型。我有为特定开发人员计算项目“兴趣度”的概念:

class Project < ActiveRecord::Base
def interestingness_for(developer)
some_integer_based_on_some_calculations
end
end

我认为这会很整洁,而不是像 Project.order_by_interestingness_for(bill) 这样的东西,能够说

Project.order(:interestingness, :developer => bill)

让它成为一个作用域而不仅仅是一个函数,这样我就可以做类似的事情

Project.order(:interestingness, :developer => bill).limit(10)

不过,我不知道该怎么做,因为对我来说如何覆盖范围并不明显。有什么建议吗?

最佳答案

假设您不需要为 Project 类使用标准的 ActiveRecord order 查询方法,您可以像任何其他类方法一样覆盖它:

def self.order(type, options)
self.send(:"special_#{type}_calculation_via_scopes", options)
end

然后诀窍是确保您创建所需的计算方法(这将根据您的兴趣和其他算法而有所不同)。并且计算方法仅使用范围或其他 AR 查询接口(interface)方法。如果您不习惯使用查询接口(interface)将方法逻辑转换为等效的 SQL,您可以尝试使用 Squeel DSL gem,它可以根据您的特定计算直接使用该方法。

如果您可能需要经典的 order 方法(这通常是一个安全的假设),那么不要覆盖它。为此目的创建一个代理非 ActiveRecord 对象,或者使用不同的命名约定。

如果您真的想要,您可以使用别名来实现类似的效果,但是如果第二个参数(在本例中为“选项”)随着 Rails 的发展突然具有另一种含义,那么从长远来看可能会产生意想不到的后果。以下是您可以使用的示例:

def self.order_with_options(type, options = nil)
if options.nil?
order_without_options(type)
else
self.send(:"special_#{type}_calculation_via_scopes", options)
end
end
class << self
alias_method_chain :order, :options
end

关于ruby - 覆盖 AR 订单范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12844113/

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