The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

ElasticSearch::ScrolledSearch - Description

SYNOPSIS

    $scroller = $es->scrolled_search($search_params);
  OR
    $scroller = ElasticSearch::ScrolledSearch($es,$search_params);

    while (my $result = $scroller->next) {
        # do something
    }

    $total  = $scroller->total;
    $bool   = $scroller->eof
    $score  = $scroller->max_score;
    $facets = $scroller->facets;

DESCRIPTION

ElasticSearch::ScrolledSearch is a convenience iterator for scrolled searches. It accepts the standard search parameters that would be passed to "search()" in ElasticSearch. The scroll parameter defaults to 1m.

    $scroller = $es->scrolled_search(
                    query  => {match_all=>{}},
                    scroll => '5m'               # keep the scroll request
                                                 # live for 5 minutes
                );

METHODS

new()

    $scroller = $es->scrolled_search($search_params);
  OR
    $scroller = ElasticSearch::ScrolledSearch($es,$search_params);

next()

    @results = $scroller->next()
    @results = $scroller->next($no_of_results);

Returns the next result, or the next $no_of_results or an empty list when no more results are available.

An error is thrown if the scroll has already expired.

If as_json => 1 is specified, then "next()" will always return a JSON array:

   $scroller->next()
   # '[{...}]'

   $scroller->next(2)
   # '[{...},{...}]'

   # if no results left: '[]'

drain_buffer()

    @docs = $scroller->drain_buffer;

Returns and removes all docs that are currently stored in the buffer.

refill_buffer()

    $buffer_size = $scroller->refill_buffer

Pulls the next set of results from ElasticSearch (if any) and returns the total number of docs stored in the internal buffer.

total()

    $total = $scroller->total

The total number of hits

max_score()

    $score = $scroller->max_score

The max_score returned from the first search request (if available).

eof()

    $bool = $scroller->eof

Returns true if no more results are available. Note: if no results match the search, then eof() could be false but the first call to next() will return zero results.

facets()

    $facets = $scroller->facets

The facets returned from the first search request (if any).

If as_json => 1 is specified, then "facets()" will always return a JSON object.

SEE ALSO

"scrolled_search()" in ElasticSearch, "search()" in ElasticSearch and "scroll()" in ElasticSearch

BUGS

None known

AUTHOR

Clinton Gormley, <clinton@traveljury.com>

COPYRIGHT AND LICENSE

Copyright (C) 2011 by Clinton Gormley

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.7 or, at your option, any later version of Perl 5 you may have available.