0

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

这是我的桌子

|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 %>

请有人可以帮我解决这个问题

我将非常感谢帮助

4

1 回答 1

1

Policies.joins(:insurances).group("policies.id").count会给你一个散列,其中键是policy.id,值是每个保单的保险数量。

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

于 2013-10-17T22:12:53.367 回答