lucene-searching.xml 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="learning.lucene.searching">
  5. <title>検索</title>
  6. <para>
  7. 検索は、<methodname>find()</methodname> メソッドを使って実行されます。
  8. </para>
  9. <example id="learning.lucene.searching.search-example">
  10. <title>インデックスを検索</title>
  11. <programlisting language="php"><![CDATA[
  12. $hits = $index->find($query);
  13. foreach ($hits as $hit) {
  14. printf("%d %f %s\n", $hit->id, $hit->score, $hit->title);
  15. }
  16. ]]></programlisting>
  17. </example>
  18. <para>
  19. この例は、2つの特別な検索ヒット・プロパティ、
  20. <property>id</property> および <property>score</property> の使用法を示します。
  21. </para>
  22. <para>
  23. <property>id</property> は、Lucene インデックス内で使用される内部的な文書識別番号です。
  24. それは、インデックスから文書を削除することを含む、様々な操作のために使われるでしょう。
  25. </para>
  26. <example id="learning.lucene.searching.delete-example">
  27. <title>索引付けされた文書を削除</title>
  28. <programlisting language="php"><![CDATA[
  29. $index->delete($id);
  30. ]]></programlisting>
  31. </example>
  32. <para>
  33. あるいは、インデックスによって文書を取得します。
  34. </para>
  35. <example id="learning.lucene.searching.retrieve-example">
  36. <title>索引付けされた文書を取得</title>
  37. <programlisting language="php"><![CDATA[
  38. $doc = $index->getDocument($id);
  39. ]]></programlisting>
  40. </example>
  41. <note id="learning.lucene.searching.identifiers">
  42. <title>内部的な文書識別番号</title>
  43. <para>
  44. 重要事項!内部的な文書識別番号は、インデックスの最適化または自動最適化処理によって変わるかもしれません。
  45. しかし、(自動最適化処理に含まれるであろう) <methodname>addDocument()</methodname>
  46. や、<methodname>optimize()</methodname> メソッドが呼び出されない限り、
  47. 単一のスクリプト実行中には決して変わりません。
  48. </para>
  49. </note>
  50. <para>
  51. <property>score</property>項目は、ヒット・スコアです。
  52. 検索結果は、デフォルトで得点によって順序づけられます。(最高の結果は、最初に戻されます)
  53. </para>
  54. <para>
  55. 特定の項目値によって結果セットを順序づけることもできます。この可能性について詳しくは、
  56. <link linkend="zend.search.lucene.searching.sorting">
  57. <classname>Zend_Search_Lucene</classname> ドキュメント</link>をご覧ください。
  58. </para>
  59. <para>
  60. その例は、格納された項目にアクセスする能力も示します。
  61. (例えば、<command>$hit->title</command>)
  62. <property>id</property> または <property>score</property>
  63. 以外のいずれかのヒット・プロパティーに初めてアクセスすると、
  64. 文書の保管された項目が読み込まれ、対応する項目値が返されます。
  65. </para>
  66. <para>
  67. これは、それら自身の <property>id</property> または <property>score</property>
  68. 項目を持つ文書にあいまいさを引き起こします。
  69. その結果、保管された文書内でそれらの項目名を使うことはお勧めしません。
  70. とはいっても、それらは <methodname>getDocument()</methodname> メソッドを通じて、
  71. 今まで通りアクセスできます。
  72. </para>
  73. <example id="learning.lucene.searching.id-score-fields">
  74. <title>オリジナル文書の "id" および "score" 項目にアクセス</title>
  75. <programlisting language="php"><![CDATA[
  76. $id = $hit->getDocument()->id;
  77. $score = $hit->getDocument()->score;
  78. ]]></programlisting>
  79. </example>
  80. </sect1>