ruby-on-rails – 如何在Rails / ActiveRecord中一次使用多个聚合函数?

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – 如何在Rails / ActiveRecord中一次使用多个聚合函数?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想一次做几个聚合函数,例如,按状态分组获取最大和最小ID:
Model.maximum(:id).minimum(:id).group(:status)

这不起作用(至少使用Rails 3.1.1) – 你在最小调用上得到一个错误,说它没有在Fixnum上定义.

NoMethodError: undefined method `minimum' for 22377:Fixnum

我可以为它做原始的sql – 但只是想知道是否有更高级别/ Rails选项…

谢谢,克里斯

解决方法

我相信@topek是对的,你不能像这样链接计算功能.我认为你必须在select谓词中使用sql,例如:
Model.select('MAX(id) AS `maximum`,MIN(id) AS `minimum`').group(:status)

我刚刚在我自己的项目中对此进行了测试,它似乎按预期工作.

猜你在找的Ruby相关文章