Programmer's Reference Guide

Indexerstellung

Einen Index durchsuchen

Abfrage erstellen

Es gibt zwei Arten, den Index zu durchsuchen. Die erste Methode verwendet den Query Parser, um eine Abfrage aus einem String zu erstellen. Die zweite ist die Möglichkeit, eigene Abfragen mithilfe der Zend_Search_Lucene Programmierschnittstelle (API) zu erstellen.

Vor der Verwendung des bereitgestellten Query Parsers, beachte bitte folgendes:

  1. Wenn du deine Abfragestrings programmseitig erstellst und dann durch den Query Parser verarbeiten lässt, solltest du ernsthaft darüber nachdenken, deine Abfragen direct mit der Programmierschnittstelle (API) für Abfragen zu erstellen. In anderen Worten, der Query Parser wurde für von Menschen eingegebene Texte und nicht für von Programmen erstellte Texte entwickelt.

  2. Nicht in einzelne Tokens aufgeteilte Felder werden am besten direkt zu der Abfrage und nicht über den Query Parser hinzugefügt. Wenn die Feldwerte durch die Anwendung programmseitig erstellt werden, dann sollte dies für Abfrageklauseln dieses Felds ebenfalls geschehen. Ein Analysator, welche der Query Parser verwendet, wurde entwickelt, um von Menschen eingegebenen Text in Begriffe zu konvertieren. Durch Programme erstellte Werte wie Datumsangaben, Schlüsselwörter, usw. sollten durchweg durch Programme erstellt werden.

  3. In einem Abfrageformular sollten generelle Textfelder den Query Parser verwenden. Alle anderen, wie z.B. Datumsbereiche, Schlüsselwörter, usw. werden besser direkt durch die Programmierschnittstelle (API) der Abfrage hinzugefügt. Ein Feld mit einem begrenzten Wertebereich, das durch ein Pulldown-Menü spezifiziert wird, sollte nicht einem Abfragestring hinzugefügt werden, der anschließend wieder geparst wird, sondern eher als eine TermQuery Klausel hinzugefügt werden.

  4. Boolesche Abfragen erlauben es, verschiedene Abfragen zu einer neuen zusammenzufügen. Deshalb ist dies der beste Weg, um zusätzliche Kriterien zu einer Benutzersuche hinzuzufügen, die durch den Abfragestring definiert wird.

Beide Arten verwenden die selbe Methode der Programmierschnittstelle (API), um den Index zu durchsuchen:

<?php
require_once 'Zend/Search/Lucene.php';

$index = Zend_Search_Lucene::open('/data/my_index');

$index->find($query);
        

Die Zend_Search_Lucene::find() Methode ermittelt den Eingabetyp automatisch und verwendet den Query Parser, um ein entsprechendes Zend_Search_Lucene_Search_Query Objekt aus dem String zu erstellen.

Es ist wichtig zu beachten, dass der Query Parser den Standard Analyzer verwendet, um verschiedene Teile des Abfragestrings in Token aufzuteilen. Dadurch werden alle Umwandlungen, die auf einen indizierten Text ausgeführt werden, auch für den Abfragestring durchgeführt.

Dies können die Umwandlung in Kleinbuchstaben, um die Suche unabhängig von Groß- und Kleinschreibung zu machen, das Entfernen von Stopwörtern, das Stemming und viele andere Dinge sein.

Im Gegensatz dazu transformieren oder filtern die API Methoden die Eingabebegriffe nicht. Deshalb passen sie besser für computergenerierte und nicht in Token aufgeteilte Felder.

Parsen der Abfrage

Die Zend_Search_Lucene_Search_QueryParser::parse() Methode kann verwendet werden um einen Abfrage String in ein Abfrage Objekt zu parsen.

Dieses Objekt kann in Abfrage erzeugenden API Methoden verwendet werden um von Benutzern eingegebene Abfragen mit Maschinen erzeugten Abfragen zu kombinieren.

Aktuell ist das in einigen Fällen der einzige Weg um nach einem Wert innerhalb eines Feldes ohne Token zu suchen:

<?php
$userQuery = Zend_Search_Lucene_Search_QueryParser::parse($queryStr);

$pathTerm  = new Zend_Search_Lucene_Index_Term('/data/doc_dir/' . $filename, 'path');
$pathQuery = new Zend_Search_Query_Term($pathTerm);

$query = new Zend_Search_Query_Boolean();
$query->addSubquery($userQuery, true /* required */);
$query->addSubquery($pathQuery, true /* required */);

$hits = $index->find($query);
                

Die Zend_Search_Lucene_Search_QueryParser::parse() Methode nimmt auch einen optionalen Encoding Parameter, welche die Codierung des Abfrage Strings definieren kann:

<?php
$userQuery = Zend_Search_Lucene_Search_QueryParser::parse($queryStr, 'iso-8859-5');
                

Wenn Codierung angegeben wurde, wird das aktuelle Gebietsschema verwendet.

Es ist auch möglich eine Standard Codierung für den Abfragestring mit der Zend_Search_Lucene_Search_QueryParser::setDefaultEncoding() Methode zu definieren:

<?php
Zend_Search_Lucene_Search_QueryParser::setDefaultEncoding('iso-8859-5');
...
$userQuery = Zend_Search_Lucene_Search_QueryParser::parse($queryStr);
                

Zend_Search_Lucene_Search_QueryParser::getDefaultEncoding() gibt die aktuelle Standard Codierung des Abfrage Strings zurück (leerer String bedeutet "aktuelles Gebietsschema").

Suchergebnisse

Das Suchergebnis ist ein Array mit Zend_Search_Lucene_Search_QueryHit Objekten. Jedes davon hat zwei Eigenschaften: $hit->document ist eine Dokumentnummer innerhalb des Index und $hit->score ist ein Punktwert für den Treffer im Suchergebnis. Das Ergebnis wird anhand der Punktwerte sortiert (beste Treffer kommen zuerst)

Das Zend_Search_Lucene_Search_QueryHit Objekt beinhaltet zudem jedes Feld des Zend_Search_Lucene_Document, das gefunden wurde, als Eigenschaft des Treffers. In diesem Beispiel, wird ein Treffer zurückgegeben und das entsprechende Dokument hat zwei Felder: Titel und Autor.

<?php
require_once('Zend/Search/Lucene.php');

$index = Zend_Search_Lucene::open('/data/my_index');

$hits = $index->find($query);

foreach ($hits as $hit) {
    echo $hit->score;
    echo $hit->title;
    echo $hit->author;
}
        

Gespeicherte Felder werden immer in UTF-8 Kodierung zurückgegeben.

Optional kann das originale Zend_Search_Lucene_Document Objekt vom Zend_Search_Lucene_Search_QueryHit Objekt zurückgegeben werden. Du kannst gespeicherte Teile des Dokuments durch Verwendung der getDocument() Methode des Indexobjektes zurückerhalten und diese dann durch die getFieldValue() Methode abfragen:

<?php
require_once 'Zend/Search/Lucene.php';

$index = Zend_Search_Lucene::open('/data/my_index');

$hits = $index->find($query);
foreach ($hits as $hit) {
    // Gibt Zend_Search_Lucene_Document Objekte für diesen Treffer zurück
    echo $document = $hit->getDocument();

    // Gibt ein Zend_Search_Lucene_Field Objekt von Zend_Search_Lucene_Document zurück
    echo $document->getField('title');

    // Gibt den String Wert des Zend_Search_Lucene_Field Objektes zurück
    echo $document->getFieldValue('title');

    // Gleich wie getFieldValue()
    echo $document->title;
}
        

Die Felder, die in einem Zend_Search_Lucene_Document Objekt verfügbar sind, werden beim Indizieren festgelegt. Die Dokumentenfelder werden durch die Indizieranwendung (z.B. LuceneIndexCreation.jar) im Dokument entweder nur indiziert oder indiziert und gespeichert.

Beachte, dass die Dokumentidentität ('path' in unserem Beispiel) auch im Index gespeichert wird und von ihm zurückgewonnen werden muß.

´Begrenzen des Ergebnisses

Der kostenintensivste Part des Suchens ist die Berechnung der Treffer. Das kann für große Ergebnisse einige Sekunden dauern (Zehntausend Treffer)

Zend_Search_Lucene bietet die Möglichkeit die Ergebnisse mit den getResultSetLimit() und setResultSetLimit() Methoden zu begrenzen:

<?php
$currentResultSetLimit = Zend_Search_Lucene::getResultSetLimit();

Zend_Search_Lucene::setResultSetLimit($newLimit);
            
0 (Standardwert) bedeutet 'keine Grenze'.

Es gibt nicht die 'besten N' Ergebnisse, sonder nur die 'ersten N' [1].

Ergebnisgewichtung

Zend_Search_Lucene verwendet die selben Gewichtungsalgorithmen wie Java Lucene. Die Treffer in den Suchergebnisse werden standardmäßig nach einem Punktwert sortiert. Treffer mit höherem Punktwert kommen zuerst, und Dokumente mit höherem Punktwert passen auf die Abfrage besser als solche mit niedrigerem Punktwert.

Grob gesagt, haben die Suchergebnisse einen höheren Punktwert, welche den gesuchten Begriff oder die gesuchte Phrase häufiger enthalten.

Der Punktwert kann über die score Eigenschaft des Treffers ermittelt werden:

<?php
$hits = $index->find($query);

foreach ($hits as $hit) {
    echo $hit->id;
    echo $hit->score;
}
        

Die Zend_Search_Lucene_Search_Similarity Klasse wird verwendet, um den Punktwert zu berechnen. Beachte den Erweiterbarkeit. Algorithmen für Punktwertermittlung Abschnitt für weitere Details.

Sortierung der Suchergebnisse

Die Suchergebnisse werden standardmäßig nach dem Punktwert sortiert. Man kann dies durch Setzen von Parametern für das Sortierfeld (oder -felder), den Sortiertyp und der Sortierreihenfolge ändern.

$index->find() Aufruf kann verschiedene optionale Parameter entgegen nehmen:

<?php
$index->find($query [, $sortField [, $sortType [, $sortOrder]]] [, $sortField2 [, $sortType [, $sortOrder]]] ...);
            

$sortField ist ein Name eines gespeicherten Feldes für das Suchergebnis

$sortType kann ausgelassen werden oder folgende Werte annehmen SORT_REGULAR (vergleiche Items normal, Standardwert), SORT_NUMERIC (vergleiche Items numerisch), SORT_STRING (vergleiche items als Strings).

$sortOrder kann ausgelassen werden oder folgende Werte annehmen SORT_ASC (sortiere in aufsteigender Folge, Standardwert), SORT_DESC (sortiere in absteigender Folge).

Beispiele:

<?php
$index->find($query, 'quantity', SORT_NUMERIC, SORT_DESC);
            
<?php
$index->find($query, 'fname', SORT_STRING, 'lname', SORT_STRING);
            
<?php
$index->find($query, 'name', SORT_STRING, 'quantity', SORT_NUMERIC, SORT_DESC);
            

Bitte beim Verwenden von nicht standardmäßigen Sortierreihenfolgen. Es erfordert die komplette Übernahme der Dokumente aus dem Index und kann die Suchperformance dramatisch verlangsamen.

Such Resultate hervorheben

Die Zend_Search_Lucene_Search_Query::highlightMatches() Methode erlaubt es HTML Dokument Terme im Kontext der Suchabfrage hervorzuheben:

<?php
$query = Zend_Search_Lucene_Search_QueryParser::parse($queryStr);
$hits = $index->find($query);
...
$highlightedHTML = $query->highlightMatches($sourceHTML);
            

Die highlightMatches() Methode verwendet die Zend_Search_Lucene_Document_Html Klasse (siehe den HTML Dokumente Abschnitt für Details) für das bearbeiten von HTML. Deshalb hat Sie die gleichen Voraussetzungen wie HTML Quellen.

[1]Zurückgegebenen Ergebnisse werden trotzdem nach dem Treffer geordnet oder auf einem anderen Weg wenn dieser definiert wurde.

Indexerstellung
blog comments powered by Disqus

Select a Version

Languages Available

Components

Search the Manual