Provided by: libcatmandu-perl_1.2020-1_all bug

NAME

       Catmandu::Searchable - Optional role for searchable stores

SYNOPSIS

           my $store = Catmandu::Store::Solr->new();

           # Return one page of search results (page size = 1000)
           my $hits  = $store->bag->search(
                  query => 'dna' ,
                  start => 0 ,
                  limit => 100 ,
                  sort  => 'title desc',
                       );

           # Return all the search results as iterator
           my $it    = $store->bag->searcher(query => 'dna');
           $it->each(sub { ...});

           $store->bag->delete_by_query(query => 'dna');

CONFIGURATION

       default_limit
           The default value for "limit". By default this is 10.

       maximum_limit
           The maximum allowed value for "limit". By default this is 1000.

       maximum_offset
           The  maximum  allowed  offset.  When  set  no  hits will be returned after hit offset is greater than
           "maximum_offset", this to avoid deep paging problems.  Pagination values will  be  also  be  adjusted
           accordingly.

METHODS

   search(query => $query, start => $start, page => $page, limit => $num, sort => $sort)
       Search  the  database  and returns a Catmandu::Hits on success. The Hits represents one result page of at
       most $num results. The $query and $sort should implement the query and  sort  syntax  of  the  underlying
       search engine.

       Optionally provide the index of the first result using the "start" option, or the starting page using the
       "page"  option.  The  number  of  records  in  a result page can be set using the "limit" option. Sorting
       options are being sent verbatim to the underlying search engine.

   searcher(query => $query, start => $start, limit => $num, sort => $sort, cql_query => $cql)
       Search the database and return a Catmandu::Iterable on success. This iterator can be used  to  loop  over
       the  complete  result  set.  The  $query  and  $sort  should  implement  the query and sort syntax of the
       underlying search engine.

       Optionally provide the index of the first result using the "start" option. The number  of  records  in  a
       page  can  be  set  using  the  "limit" option. Sorting options are being sent verbatim to the underlying
       search engine.

   delete_by_query(query => $query)
       Delete items from the database that match $query

CQL support

       Stores that are support the CQL query language <https://www.loc.gov/standards/sru/cql/> also  accept  the
       "cql_query" and "sru_sortkeys" arguments. See Catmandu::CQLSearchable for more information.

SEE ALSO

       Catmandu::CQLSearchable, Catmandu::Hits, Catmandu::Paged

perl v5.36.0                                       2023-03-03                          Catmandu::Searchable(3pm)