Iterators
The PHP client includes helpers for iterating through results by page or by hits.
Use the SearchResponseIterator
to iterate page by page in a search result using pagination.
Here’s an example:
use Elastic\Elasticsearch\Helper\Iterators\SearchResponseIterator;
$search_params = [
'scroll' => '5m',1
'index' => '<name of index>',2
'size' => 100,3
'body' => [
'query' => [
'match_all' => new StdClass4
]
]
];
// $client is Elasticsearch\Client instance
$pages = new SearchResponseIterator($client, $search_params);
// Sample usage of iterating over page results
foreach($pages as $page) {
// do something with hit e.g. copy its data to another index
// e.g. prints the number of document per page (100)
echo count($page['hits']['hits']), PHP_EOL;
}
- period to retain the search context
- here the index name
- 100 results per page
- {} in JSON
Use the SearchHitIterator
to iterate in a SearchResponseIterator
without worrying about pagination.
Here’s an example:
use Elastic\Elasticsearch\Helper\Iterators\SearchHitIterator;
use Elastic\Elasticsearch\Helper\Iterators\SearchResponseIterator;
$search_params = [
'scroll' => '5m',1
'index' => '<name of index>',2
'size' => 100,3
'body' => [
'query' => [
'match_all' => new StdClass4
]
]
];
// $client is Elasticsearch\Client instance
$pages = new SearchResponseIterator($client, $search_params);
$hits = new SearchHitIterator($pages);
// Sample usage of iterating over hits
foreach($hits as $hit) {
// do something with hit e.g. write to CSV, update a database, etc
// e.g. prints the document id
echo $hit['_id'], PHP_EOL;
}
- period to retain the search context
- here the index name
- 100 results per page
- {} in JSON