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

ruby-on-rails – group_by和count

发布时间:2020-12-17 02:52:54 所属栏目:百科 来源:网络整理
导读:@entries_by_source = Entry.joins(:training_entries).group("source_id,classification_id,category_id").select("source_id,category_id,count(*) as entries_count") 这些都在@entires_by_source中 - !ruby/ActiveRecord:Entry attributes: source_id: 1
@entries_by_source = Entry.joins(:training_entries).group("source_id,classification_id,category_id").select("source_id,category_id,count(*) as entries_count")

这些都在@entires_by_source中

- !ruby/ActiveRecord:Entry 
  attributes: 
    source_id: 1
    classification_id: 1
    category_id: 1
    entries_count: 198
- !ruby/ActiveRecord:Entry 
  attributes: 
    source_id: 1
    classification_id: 1
    category_id: 2
    entries_count: 614
- !ruby/ActiveRecord:Entry 
  attributes: 
    source_id: 2
    classification_id: 1
    category_id: 3
    entries_count: 1

现在我正在尝试打印这样的东西:

source_id entries_count
1          812 #sum of entries_count 198 + 614
2          1

以下代码无效.任何帮助将不胜感激

<% @entries_by_source.group_by(&:source_id).each do |source_id,entries_count| %>
  <%= source_id %><%= entries_count %>
<% end %>

解决方法

group_by会返回一个数组

[{‘source_id_1’=> [values,…]},{‘source_id_2’=> [值,……]}]

你需要总计数,如:

<% @entries_by_source.group_by(&:source_id).each do |source_id,entries| %>
  <%= source_id %><%= entries.sum(&:entries_count) %>
<% end %>

(编辑:李大同)

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

    推荐文章
      热点阅读