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

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

现在我想用订单所具有的产品的最高价格对订单进行排序.

这是我的代码:

@orders = Order.group(arel_table[:id]).
                order(Product.arel_table[:price].maximum)

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

@orders = Order.group(arel_table[:id]).
                order(Product.arel_table[:price].maximum.desc)

我收到这样的错误:

undefined method `desc' for #<Arel::Nodes::Max:0x007fb2ab9104a0>

如何将订单排序为DESC?

最佳答案 这可能有效:

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

请参阅:

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

点赞