微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

红宝石 – 轨道3组和和

我有以下型号:
activity_types: id,name

activities: id,id_activity_type,occurrences,date (other fields)

活动表存储活动每天发生多少次.但是现在我想向用户展示每个类型每月发生多少活动.

我得到以下解决方based on this post似乎可以:

Activity.all(:joins => :activity_types,:select => "activity_types.id,activity_types.name,SUM(activities.occurrences) as occurrences",:group => "activity_types.id,activity_types.name",:order => "activity_types.id")

但这似乎是很多代码的轨道标准和rails API says it’s deprecated.

我发现以下解决方案很简单:

Activity.sum(:occurrences).group(:activity_type_id)

其返回一个散列与activity_type_id =>发生.

我可以做什么来获取以下哈希:activity_type.name =>发生?

解决方法

如果原始查询工作,那么只需尝试使用Rails 3语法重写它:
Activity.joins(:activity_types)
  .select("activity_types.id,SUM(activities.occurrences) as occurrences")
  .group("activity_types.id,activity_types.name")
  .order("activity_types.id")

原文地址:https://www.jb51.cc/ruby/271715.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐