红宝石 – 轨道3组和和
发布时间:2020-12-16 19:42:05 所属栏目:百科 来源:网络整理
导读:我有以下型号: activity_types: id,nameactivities: id,id_activity_type,occurrences,date (other fields) 活动表存储活动每天发生多少次.但是现在我想向用户展示每个类型每月发生多少活动. 我得到以下解决方案based on this post似乎可以: Activity.all(
我有以下型号:
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") (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |