3

私はレールの初級から中級レベルにゆっくりと移行しています。私のクエストでは、特定のクエリの読み込みに時間がかかるという問題が発生しています。

私の Index Action Query のパフォーマンスを向上させる可能性のあるいくつかの点を誰かが指摘できるかどうか疑問に思っています。

Rails 3.2.0、ruby 1.9.3p194、および MySQL の実行

現在、すべての機関 (約 7000) をリストしていますが、読み込みに 10 秒かかります...

マイ インデックス アクション

  def index
    @institution = Institution.includes(:state).all
  end

意見

<tbody>
    <% @institution.each do |c| %>
    <tr>
        <td><%= c.company %></td>
        <td><%= c.state.name %></td>
        <td><%= number_to_human(c.assets) %></td>
        <td><%= c.hadademo %></td>
        <td><%= c.datebecameclient %></td>
        <td><%= c.clientorprospect %></td>
        <% if current_user.admin? %>
            <td><%= link_to 'Edit', edit_institution_path(c), :class => 'btn btn-mini btn-warning'  %></td>
        <% end %>
    </tr>
    <% end %>
</tbody>

機関モデル

class Institution < ActiveRecord::Base
  attr_accessible :company, :phone, :clientdate, :street, :city, :state_id, :zip, :source, :source2, :demodate1, :demodate2, :demodate3, :client, :prospect, :notcontacted, :solveid
  belongs_to :state
  has_many :users, :through => :company_reps
  has_many :company_reps


  def points
    points_for_client + points_for_demodate1
  end

  def hadademo
    if demodate3.present?
        demodate3.to_date
    elsif demodate2.present?    
        demodate2.to_date
    elsif demodate1.present?    
        demodate1.to_date
    else
        "No Demo"
    end 
  end

  def datebecameclient
    if clientdate.present?
        clientdate.to_date
    else
        "Not a Client"
    end 
  end

  def clientorprospect
      if client?
            "Client"
        elsif prospect? 
            "Prospect"
        else
            "No Contact"
        end 
  end

  def points_for_demodate1
    if demodate1.present? && demodate1 >= Date.new(2012, 2, 23) or demodate2.present? && demodate2 >= Date.new(2012, 2, 23) or demodate3.present? && demodate3 >= Date.new(2012, 2, 23)
      1
    else
      0
    end
  end

  def clientcount
    if client?
      1
    else
      0
    end
  end

  def points_for_client
    if client?
      10 / users.count
    else
      0
    end
  end


end

Jqueryデータテーブルの使用

jQuery ->
    $("#institutions").dataTable
      sDom: "<'row-fluid'<'span6'l><'span6'f>r>t<'row-fluid'<'span6'i><'span6'p>>"
      sPaginationType: "bootstrap"

ログファイル

Started GET "/institutions" for xxx.xxx.xxx.xxx at 2012-11-13 02:51:47 +0000
Processing by InstitutionsController#index as HTML
  Rendered layouts/_messages.html.erb (1.2ms)
  Rendered institutions/index.html.erb within layouts/application (37190.3ms)
  Rendered layouts/_messages.html.erb (0.1ms)
  Rendered layouts/_navbar.html.erb (17.0ms)
Completed 200 OK in 43334ms (Views: 37983.7ms | ActiveRecord: 340.7ms)
  Rendered institutions/index.html.erb within layouts/application (34329.1ms)
  Rendered layouts/_messages.html.erb (0.1ms)
  Rendered layouts/_navbar.html.erb (23.3ms)
Completed 200 OK in 38824ms (Views: 34374.8ms | ActiveRecord: 82.2ms)
4

2 に答える 2

2

一般的に行うべきことがいくつかあります。

  1. キャッシング。データベースを完全にスキップすると大幅な高速化が得られるため、フラグメントキャッシュを調べてください。
  2. DB インデックス。関連付けられたモデルをロードしているため、関連する外部キーがインデックス化されていることを確認すると、パフォーマンスが向上する場合があります。
  3. 遅延読み込み。最初の 100 レコードのみをレンダリングし、ユーザーがそれらを参照するときに AJAX によってさらにレコードをロードすることができます。

それ以外に、生成されたクエリを投稿すると、さらなるヒントを得るのに役立つ場合があります。

于 2012-11-13T03:13:10.793 に答える
2

ログを見ると、実際のクエリではなく、ビューのレンダリングにすべての時間が費やされていることがわかります。これを高速化するには、ビューまたはアクションのキャッシュを実装する必要があります。

公式ドキュメントはあなたを正しい方向に向けます。

于 2012-11-13T03:56:12.640 に答える