在Rails中分组时获取记录属性的总和?

时间:2013-06-03 18:42:49

标签: ruby-on-rails-3 group-by sum

我在Rails 3.2应用程序中按月对里程条目进行分组:

mileages_controller.rb

  def index
    @mileages = Mileage.find_all_by_user_id(current_user.id)
    @mileages_months = Mileage.find_all_by_user_id(current_user.id).group_by { |t| t.created_at.beginning_of_month }

    respond_to do |format|
      format.html # index.html.erb
      format.json { render json: @mileages }
    end
  end

index.html.erb

<% @mileages_months.sort.each do |month, mileages| %>
  <h4><%= month.strftime('%B %Y') %></h4>
  <p>Total miles <strong><%= mileages.miles.sum %></strong>.</p>
  <table>
    <tr>
      <th>Name</th>
      <th>Miles</th>
      <th>Start</th>
      <th>Destination</th>
      <th></th>
    </tr>
      <% for mileage in mileages %>
        <tr>
          <td><%= mileage.name %></td>
          <td><%= mileage.miles %></td>
          <td><%= mileage.start %></td>
          <td><%= mileage.end %></td>
          <td><%= link_to 'Show', mileage %></td>
        </tr>
      <% end %>
</table>
<% end %>

如您所见,我正在尝试使用<%= mileages.miles.sum %>对每个月的总里程求和。这不起作用 - 但<%= mileages.first.miles %>正确显示每个月的第一个条目里程。

每月总计里程列的正确方法是什么?

1 个答案:

答案 0 :(得分:1)

你可以在mileage_helper中创建一个帮助方法(以保持逻辑与视图分离):

def sum_mileges(mileages)
  mileages.map(&:miles).sum
end

然后在视图中将其称为

<p>Total miles <strong><%= sum_mileges(mileages) %></strong>.</p>

OR

你可以直接做到:

<p>Total miles <strong><%= mileages.map(&:miles).sum %></strong>.</p>