加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-17 04:35:36 所属栏目:百科 来源:网络整理
导读:我想一次做几个聚合函数,例如,按状态分组获取最大和最小ID: Model.maximum(:id).minimum(:id).group(:status) 这不起作用(至少使用Rails 3.1.1) – 你在最小调用上得到一个错误,说它没有在Fixnum上定义. NoMethodError: undefined method `minimum' for 223
我想一次做几个聚合函数,例如,按状态分组获取最大和最小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)

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读