NAME

KSx::Searcher::Abstract - build searches from Perl data structures

VERSION

0.002

SYNOPSIS

use KSx::Searcher::Abstract;

my $searcher = KSx::Searcher::Abstract->new(%args);

my $hits = $searcher->search(\%query, \%options);

DESCRIPTION

KSx::Searcher::Abstract is intended to be a simple and flexible search builder for KinoSearch, analogous to SQL::Abstract and its role in the DBI world.

Wherever possible, KSx::Searcher::Abstract copies or mimics SQL::Abstract's query building behavior.

LIMITATIONS

Currently, only a single level of query data is supported, e.g.

$searcher->search({ foo => 1, bar => 2 })

All queries are effectively joined with AND.

In the future, nested conditions and conditions joined with OR should be supported.

METHODS

my $hits = $searcher->search(\%query, \%options);

Build a query and search with it. See "QUERY SYNTAX" and KinoSearch::Searcher.

build_abstract

my %arg = $searcher->build_abstract(\%query, \%options);

Builds input for KinoSearch::Searcher from the supplied query and options hashrefs. This is called automatically by search; you should not need to use it.

QUERY SYNTAX

Each query is built from a hashref. The keys are field names and the values are constraints.

The simplest kind of constraint is a scalar. This translates directly into a TermQuery for that field and value.

{ foo => 1 }

More complex constraints are available using a hashref.

{ foo => { '='  => 1 } } # foo = 1, equivalent to the first example
{ foo => { '!=' => 1 } } # foo != 1

Watch this space as more constraints become available (see "LIMITATIONS").

AUTHOR

Hans Dieter Pearcey, <hdp at cpan.org>

BUGS

Please report any bugs or feature requests to bug-ksx-searcher-abstract at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=KSx-Searcher-Abstract. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

SUPPORT

You can find documentation for this module with the perldoc command.

perldoc KSx::Searcher::Abstract

You can also look for information at:

ACKNOWLEDGEMENTS

COPYRIGHT & LICENSE

Copyright 2007 Hans Dieter Pearcey, all rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.