サポートされるクエリー

検索結果のページ化

上記 のように、検索結果ヒット・オブジェクトでは、格納された文書項目に対して 遅延読み込みを使います。格納された項目のどれかがアクセスされると、 全ての文書が読み込まれます。

もし、実際にはその一部だけで作業したい場合、全ての文書を取り出ししないでください。 検索結果を調べて、次のスクリプト実行中に文書をインデックスから取り出すために、 文書ID(任意にスコア)をどこかに保存してください。

Example #1 検索結果のページ化例

  1. $cacheId = md5($query);
  2.  
  3. if (!$resultSet = $cache->load($cacheId)) {
  4.     $hits = $index->find($query);
  5.     $resultSet = array();
  6.     foreach ($hits as $hit) {
  7.         $resultSetEntry          = array();
  8.         $resultSetEntry['id']    = $hit->id;
  9.         $resultSetEntry['score'] = $hit->score;
  10.  
  11.         $resultSet[] = $resultSetEntry;
  12.     }
  13.  
  14.     $cache->save($resultSet, $cacheId);
  15. }
  16.  
  17. $publishedResultSet = array();
  18. for ($resultId = $startId; $resultId < $endId; $resultId++) {
  19.     $publishedResultSet[$resultId] = array(
  20.         'id'    => $resultSet[$resultId]['id'],
  21.         'score' => $resultSet[$resultId]['score'],
  22.         'doc'   => $index->getDocument($resultSet[$resultId]['id']),
  23.     );
  24. }

サポートされるクエリー