Getting Started with Zend_Search_Lucene. Search result pagination

Translations of this material:

into Russian: Перевод "Getting Started with Zend_Search_Lucene. Search result pagination". Translation is not started yet.
Submitted for translation by antdmi 29.04.2011

Text

As mentioned above, search result hit objects use lazy loading for stored document fields. When any stored field is accessed, the complete document is loaded.

Do not retrieve all documents if you actually need to work only with some portion of them. Go through the search results and store document IDs (and optionally the score) somewhere to retrive documents from the index during the next script execution.

Example #1 Search result pagination example

  01. $cacheId = md5($query);

  02.  

  03. if (!$resultSet = $cache->load($cacheId)) {

  04.     $hits = $index->find($query);

  05.     $resultSet = array();

  06.     foreach ($hits as $hit) {

  07.         $resultSetEntry          = array();

  08.         $resultSetEntry['id']    = $hit->id;

  09.         $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. }