Search/Lucene/Search/Query/Phrase.php

Show: PublicProtectedPrivateinherited
Table of Contents
Zend Framework
LICENSE This source file is subject to the new BSD license that is bundled with this package in the file LICENSE.txt. It is also available through the world-wide-web at this URL: http://framework.zend.com/license/new-bsd If you did not receive a copy of the license and are unable to obtain it through the world-wide-web, please send an email to license@zend.com so we can send you a copy immediately.
Category
Zend  
Copyright
Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)  
License
New BSD License  
Package
Zend_Search_Lucene  
Subpackage
Search  
Version
$Id$  

\Zend_Search_Lucene_Search_Query_Phrase

Package: Zend_Search_Lucene\Search
A Query that matches documents containing a particular sequence of terms.
Parent(s)
\Zend_Search_Lucene_Search_Query
Category
Zend  
Copyright
Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)  
License
New BSD License  

Properties

>VPropertyprivatearray $_offsets
Term positions (relative positions of terms within the phrase).
Array of integers
Details
Type
array
>VPropertyprivatearray $_resVector = null
Result vector.
Default valuenullDetails
Type
array
>VPropertyprivateinteger $_slop
Sets the number of other words permitted between words in query phrase.
If zero, then this is an exact phrase search. For larger values this works like a WITHIN or NEAR operator. The slop is in fact an edit-distance, where the units correspond to moves of terms in the query phrase out of position. For example, to switch the order of two words requires two moves (the first move places the words atop one another), so to permit re-orderings of phrases, the slop must be at least two. More exact matches are scored higher than sloppier matches, thus search results are sorted by exactness. The slop is zero by default, requiring exact matches.
Details
Type
integer
>VPropertyprivatearray $_terms
Terms to find.
Array of Zend_Search_Lucene_Index_Term objects.
Details
Type
array
>VPropertyprivatearray $_termsPositions = array()
Terms positions vectors.
Array of Arrays: term1Id => (docId => array( pos1, pos2, ... ), ...) term2Id => (docId => array( pos1, pos2, ... ), ...)
Default valuearray()Details
Type
array

Methods

methodpublic__construct(array $terms = null, array $offsets = null, string $field = null) : void

Class constructor. Create a new prase query.

Parameters
NameTypeDescription
$termsarray

Terms to search Array of strings.

$offsetsarray

Relative term positions. Array of integers.

$fieldstring

Field to search.

Throws
ExceptionDescription
\Zend_Search_Lucene_Exception
methodpublic__toString() : string

Print a query

Returns
TypeDescription
string
methodpublic_exactPhraseFreq(integer $docId) : float

Score calculator for exact phrase queries (terms sequence is fixed)

Parameters
NameTypeDescription
$docIdinteger
Returns
TypeDescription
float
methodprotected_highlightMatches(\Zend_Search_Lucene_Search_Highlighter_Interface $highlighter) : void

Query specific matches highlighting

Parameters
NameTypeDescription
$highlighter\Zend_Search_Lucene_Search_Highlighter_Interface

Highlighter object (also contains doc for highlighting)

methodpublic_sloppyPhraseFreq(integer $docId, \Zend_Search_Lucene_Interface $reader) : float

Score calculator for sloppy phrase queries (terms sequence is fixed)

Parameters
NameTypeDescription
$docIdinteger
$reader\Zend_Search_Lucene_Interface
Returns
TypeDescription
float
methodpublicaddTerm(\Zend_Search_Lucene_Index_Term $term, integer $position = null) : void

Adds a term to the end of the query phrase.

The relative position of the term is specified explicitly or the one immediately after the last term added.
Parameters
NameTypeDescription
$term\Zend_Search_Lucene_Index_Term
$positioninteger
methodpubliccreateWeight(\Zend_Search_Lucene_Interface $reader) : \Zend_Search_Lucene_Search_Weight

Constructs an appropriate Weight implementation for this query.

Parameters
NameTypeDescription
$reader\Zend_Search_Lucene_Interface
Returns
TypeDescription
\Zend_Search_Lucene_Search_Weight
methodpublicexecute(\Zend_Search_Lucene_Interface $reader, \Zend_Search_Lucene_Index_DocsFilter | null $docsFilter = null) : void

Execute query in context of index reader It also initializes necessary internal structures

Parameters
NameTypeDescription
$reader\Zend_Search_Lucene_Interface
$docsFilter\Zend_Search_Lucene_Index_DocsFilter | null
methodpublicgetQueryTerms() : array

Return query terms

Returns
TypeDescription
array
methodpublicgetSlop() : integer

Get slop

Returns
TypeDescription
integer
methodpublicgetTerms() : array

Returns query term

Returns
TypeDescription
array
methodpublicmatchedDocs() : array

Get document ids likely matching the query

It's an array with document ids as keys (performance considerations)
Returns
TypeDescription
array
methodpublicoptimize(\Zend_Search_Lucene_Interface $index) : \Zend_Search_Lucene_Search_Query

Optimize query in the context of specified index

Parameters
NameTypeDescription
$index\Zend_Search_Lucene_Interface
Returns
TypeDescription
\Zend_Search_Lucene_Search_Query
methodpublicrewrite(\Zend_Search_Lucene_Interface $index) : \Zend_Search_Lucene_Search_Query

Re-write query into primitive queries in the context of specified index

Parameters
NameTypeDescription
$index\Zend_Search_Lucene_Interface
Returns
TypeDescription
\Zend_Search_Lucene_Search_Query
methodpublicscore(integer $docId, \Zend_Search_Lucene_Interface $reader) : float

Score specified document

Parameters
NameTypeDescription
$docIdinteger
$reader\Zend_Search_Lucene_Interface
Returns
TypeDescription
float
methodpublicsetSlop(integer $slop) : void

Set slop

Parameters
NameTypeDescription
$slopinteger
methodpublicsetWeight(integer $num, \Zend_Search_Lucene_Search_Weight_Term $weight) : void

Set weight for specified term

Parameters
NameTypeDescription
$numinteger
$weight\Zend_Search_Lucene_Search_Weight_Term
Documentation was generated by phpDocumentor 2.2.0 .