我怎样才能在我的视图中计算一列?

时间:2013-10-17 22:06:56

标签: ruby-on-rails ruby ruby-on-rails-2

我做了一个应用程序来显示另一个表中的列,但我想知道如何计算结果而不是显示信息

这是我的表格

|policies|
 |id|  |num_policy|
   1       11111
   2       22222

|insurances|
 |id|  |id_policy| |net_insurance|
  1        1          33333
  2        1          44444  
  3        2          55555
  4        2          66666  

|insurance_financing|       
  |id| |id_ensurance| |number|
   1       1            1544
   2       2             858
   3       3            8484  
   4       4             848

我正在尝试

|num_policy|    |count| 
     11111       2
     22222       2

这是我的控制器

class PolicyController < ApplicationController
    def generate_print
      @policies= Policy.find(:all)
    end
end

这是我的模特

class Policy < ActiveRecord::Base
  has_many :insurances
end

class Insurance < ActiveRecord::Base
  belongs_to :policy
  has_many :insurance_financing_details
end

class InsuranceFinancingDetail < ActiveRecord::Base
  belongs_to :insurance
end        

这是我的观点

 <% @policies.each do |p| %>
    <%= p.num_policy   %>

    <%  p.insurances.each do |insurance| %>
       <% insurance.insurance_financing_details.each do |detail| %>
          <%= detail.number %>
       <% end %>
    <% end %>
 <% end %>

请有人帮我解决这个问题

我真的很感激帮助

1 个答案:

答案 0 :(得分:1)

Policies.joins(:insurances).group("policies.id").count将为您提供一个散列,其中键是policies.id,值是每个策略的保险计数。

注意:如果保单没有任何保险,则不会包含在结果中。