Rails 4:尝试使用 arel_table.maximum.desc 排序时出错

Pen*_* Qi 5 mysql sorting ruby-on-rails

我得到了一个Order和 一个Product具有多对多关系的模型。所以一个订单has_many产品,每一个都有不同的价格。

现在我想按照订单所含产品的最高价格对订单进行排序。

这是我的代码:

@orders = Order.group(arel_table[:id]).
                order(Product.arel_table[:price].maximum)
Run Code Online (Sandbox Code Playgroud)

它与默认的 ASC 顺序完美配合,但是当我将其按 DESC 顺序排序时,如下所示:

@orders = Order.group(arel_table[:id]).
                order(Product.arel_table[:price].maximum.desc)
Run Code Online (Sandbox Code Playgroud)

我收到这样的错误:

undefined method `desc' for #<Arel::Nodes::Max:0x007fb2ab9104a0>
Run Code Online (Sandbox Code Playgroud)

如何按 DESC 对订单进行排序?

Jun*_*Ito 3

这可能有效:

@orders = Order
            .group(arel_table[:id]) # Maybe Order.arel_table[:id] 
            .order(Arel::Nodes::Descending.new(Product.arel_table[:price].maximum))
Run Code Online (Sandbox Code Playgroud)

另请参阅:

http://www.rubydoc.info/github/rails/arel/Arel/OrderPredicates#desc-instance_method