performance-database.xml 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="performance.database">
  5. <title>Zend_Dbパフォーマンス</title>
  6. <para>
  7. <classname>Zend_Db</classname>はデータベースを抽象化するレイヤーで、
  8. <acronym>SQL</acronym>操作のための共通<acronym>API</acronym>を提供する意図があります。
  9. <classname>Zend_Db_Table</classname>はテーブルデータのゲートウェイで、
  10. テーブルレベルでの抽象的な共通のデータベース操作を提供する意図があります。
  11. それらの抽象的な性質とそれらの操作を行なうために隠れて行なうマジックのせいで、
  12. しばしばパフォーマンスのオーバーヘッドをもたらします。
  13. </para>
  14. <sect2 id="performance.database.tableMetadata">
  15. <title>テーブルのメタデータを取得する際にZend_Db_Tableによってもたらされる
  16. オーバーヘッドをどのようにしたら減らせますか?</title>
  17. <para>
  18. できる限り使い方を簡単に保つために、
  19. また、開発最中にスキーマの変更を絶えずサポートするためにも、
  20. <classname>Zend_Db_Table</classname>はあるマジックを隠れて行ないます:
  21. 使い始める時にテーブルのスキーマを読み込んでオブジェクトのメンバに保存します。
  22. この操作は一般的に高くつき、データベースを気にかけません。
  23. それは製品のボトルネックに寄与します。
  24. </para>
  25. <para>
  26. 幸運なことにその状況を改善する技術があります。
  27. </para>
  28. <sect3 id="performance.database.tableMetadata.cache">
  29. <title>メタデータキャッシュの利用</title>
  30. <para>
  31. <classname>Zend_Db_Table</classname>ではテーブルのメタデータをキャッシュする
  32. ために<classname>Zend_Cache</classname>を任意で利用できます。
  33. これはデータベース自身からメタデータを読み込むよりも、
  34. 一般的に早くアクセスでき、高くつきません。
  35. </para>
  36. <para>
  37. <link linkend="zend.db.table.metadata.caching"><classname>Zend_Db_Table</classname>
  38. のドキュメントにメタデータをキャッシュすることについて情報があります。</link>
  39. </para>
  40. </sect3>
  41. <sect3 id="performance.database.tableMetadata.hardcoding">
  42. <title>テーブル定義でメタデータをハードコーディングする</title>
  43. <para>
  44. 1.7.0では、<classname>Zend_Db_Table</classname>は<link
  45. linkend="zend.db.table.metadata.caching.hardcoding">テーブルの定義でメタデータをハードコーディングすることをサポート</link>
  46. することもします。
  47. これは高度な使用例であり、テーブルのスキーマが変更されそうにないと知っているか、
  48. または定義を最新状態に保ち続けられる時のみ利用されるべきでしょう。
  49. </para>
  50. </sect3>
  51. </sect2>
  52. <sect2 id="performance.database.select">
  53. <title>
  54. Zend_Db_Selectで生成されたSQLがインデックスにヒットしません。
  55. どのようにしたらより良く出来ますか?
  56. </title>
  57. <para>
  58. <classname>Zend_Db_Select</classname>は比較的その仕事が得意です。
  59. ただし、結合や副選択を必要とする複雑なクエリを実行するなら、
  60. しばしばかなりの素人になりえます。
  61. </para>
  62. <sect3 id="performance.database.select.writeyourown">
  63. <title>自分で最適化したSQLを書く</title>
  64. <para>
  65. 現実的な唯一の答えは自分で<acronym>SQL</acronym>を書くことです;
  66. 自分で用意できるなら、<classname>Zend_Db</classname>で必ず
  67. <classname>Zend_Db_Select</classname>を使わずに、<acronym>SQL</acronym>のselect文を調整する
  68. ことがもっとも完璧に筋の通った道です。
  69. </para>
  70. <para>
  71. <constant>EXPLAIN</constant> をクエリに対して実行して、
  72. 最もパフォーマンスのあるインデックスを本当に当てるまで、
  73. さまざまな取り組みをテストしてください。
  74. それからクラスのプロパティーや定数として<acronym>SQL</acronym>をハードコーディングしてください。
  75. </para>
  76. <para>
  77. もし<acronym>SQL</acronym>が変数の引数を必要とする場合、
  78. <acronym>SQL</acronym>にプレースホルダーを用意してください。
  79. そして、<acronym>SQL</acronym>に値を挿入するために <methodname>vsprintf()</methodname>
  80. と <methodname>array_map()</methodname> の組み合わせを利用してください。
  81. </para>
  82. <programlisting language="php"><![CDATA[
  83. // $adapter はDBアダプターです。Zend_Db_Tableでは、
  84. // $this->getAdapter() を使ってそれを参照します
  85. $sql = vsprintf(
  86. self::SELECT_FOO,
  87. array_map(array($adapter, 'quoteInto'), $values)
  88. );
  89. ]]></programlisting>
  90. </sect3>
  91. </sect2>
  92. </sect1>
  93. <!--
  94. vim:se ts=4 sw=4 et:
  95. -->