Search::Xapian::Database - Search database object


Search-Xapian documentation Contained in the Search-Xapian distribution.

Index


Code Index:

NAME

Top

Search::Xapian::Database - Search database object

DESCRIPTION

Top

This class represents a Xapian database for searching. See Search::Xapian::WritableDatabase for an object suitable for indexing. To perform searches, this class works with the Search::Xapian::Query object.

METHODS

Top

new <database>

Class constructor. Can either take a path to an existing database or another database class as the first parameter

clone

Return a clone of this class.

add_database

Add an existing database (or group of databases) to those accessed by this object.

reopen

This re-opens the database(s) to the latest available version(s). It can be used either to make sure the latest results are returned, or to recover from a Xapian::DatabaseModifiedError.

close

Close the database. This also implies a commit() unless a transaction is in progress.

enquire [<query>]

Returns a new Search::Xapian::Enquire object. Any extra parameters are passed to set_query.

get_doccount

Returns the number of document indexed in this database.

get_lastdocid

Returns the id of the last used document.

get_doclength <doc_id>

Returns the length of a given document.

get_document <doc_id>

Returns a Search::Xapian::Document object for the given document.

get_avlength

Get the average length of the documents in the database.

get_termfreq <term>

Get the number of documents in the database indexed by a given term.

term_exists <term>

returns true if this term exists in the database, or false otherwise.

get_description

return a description of this object.

get_spelling_suggestion

returns a suggested spelling correction.

allterms_begin [<prefix>]

Returns a Search::Xapian::TermIterator iterating over the termlist for the the entire database. If the optional prefix argument is non-empty, only terms starting with that string are returned.

allterms_end [<prefix>]

Returns a Search::Xapian::TermIterator pointing to the end of the termlist corresponding to allterms_begin.

termlist_begin <docid>

Returns a Search::Xapian::TermIterator pointing to the start of the termlist for a given document.

termlist_end <docid>

Returns a Search::Xapian::TermIterator pointing to the end of the termlist for a given document.

positionlist_begin <docid> <term>

Returns a Search::Xapian::PositionIterator pointing to the start of the position list for a given term in the given document.

positionlist_end <docid> <term>

Returns a Search::Xapian::PositionIterator pointing to the end of the position list for a given term in the given document.

postlist_begin <term>

Returns a Search::Xapian::PostingIterator pointing to the start of the posting list for a given term.

postlist_end <term>

Returns a Search::Xapian::PostingIterator pointing to the end of the posting list for a given term.

keep_alive

Send a "keep-alive" to remote databases to stop them timing out.

get_collection_freq <term>

Get the number of elements indexed by a certain term.

SEE ALSO

Top

Search::Xapian,Search::Xapian::Enquire,Search::Xapian::WritableDatabase


Search-Xapian documentation Contained in the Search-Xapian distribution.

package Search::Xapian::Database;

use 5.006;
use strict;
use warnings;
use Carp;

use Search::Xapian::Enquire;

require DynaLoader;

our @ISA = qw(DynaLoader);

# In a new thread, copy objects of this class to unblessed, undef values.
sub CLONE_SKIP { 1 }

# Preloaded methods go here.

use overload '='  => sub { $_[0]->clone() },
             'fallback' => 1;

sub enquire {
  my $self = shift;
  my $enquire = Search::Xapian::Enquire->new( $self );
  if( @_ ) {
    $enquire->set_query( @_ );
  }
  return $enquire;
}


sub clone() {
  my $self = shift;
  my $class = ref( $self );
  my $copy = new2( $self );
  bless $copy, $class;
  return $copy;
}

sub new() {
  my $class = shift;
  my $database;
  my $invalid_args;
  if( scalar(@_) == 1 ) {
    my $arg = shift;
    my $arg_class = ref( $arg );
    if( !$arg_class ) {
      $database = new1( $arg );
    } elsif( $arg_class eq $class ) {
      $database = new2( $arg );
    } else {
      $invalid_args = 1;
    }
  } else {
    $invalid_args = 1;
  }
  if( $invalid_args ) {
    Carp::carp( "USAGE: $class->new(\$file), $class->new(\$database)" );
    exit;
  }
  bless $database, $class;
  return $database;
}

1;

__END__