PHP Класс yii\sphinx\MatchExpression

In conjunction with MatchBuilder this class provides ability to build sophisticated MATCH expressions. Instance of this class can be passed to [[Query::match()]]. For example: php use yii\sphinx\Query; use yii\sphinx\MatchExpression; $rows = (new Query()) ->match(new MatchExpression('@title :title', ['title' => 'Yii'])) ->all(); You may use MatchExpression::match, MatchExpression::andMatch and MatchExpression::orMatch to combine several conditions. For example: php use yii\sphinx\Query; use yii\sphinx\MatchExpression; $rows = (new Query()) ->match( produces '((@title "Yii") (@author "Paul")) | (@content "Sphinx")' : (new MatchExpression()) ->match(['title' => 'Yii']) ->andMatch(['author' => 'Paul']) ->orMatch(['content' => 'Sphinx']) ) ->all(); You may as well compose expressions with special operators like 'MAYBE', 'PROXIMITY' etc. For example: php use yii\sphinx\Query; use yii\sphinx\MatchExpression; $rows = (new Query()) ->match( produces '@title "Yii" MAYBE "Sphinx"' : (new MatchExpression())->match([ 'maybe', 'title', 'Yii', 'Sphinx', ]) ) ->all(); $rows = (new Query()) ->match( produces '@title "Yii"~10' : (new MatchExpression())->match([ 'proximity', 'title', 'Yii', 10, ]) ) ->all(); Note: parameters passed via [[params]] or generated from array conditions will be automatically escaped using [[Connection::escapeMatchValue()]].
См. также: MatchBuilder
См. также: http://sphinxsearch.com/docs/current.html#extended-syntax
С версии: 2.0.6
Автор: Paul Klimov ([email protected])
Наследование: extends yii\base\Object
Показать файл Открыть проект

Открытые свойства

Свойство Тип Описание
$match MATCH expression. For example: ['title' => 'Yii', 'content' => 'Sphinx']. Note: being specified as a plain string this value will not be quoted or escaped, do not pass possible unsecured values (like the ones obtained from HTTP request) as a direct value.
$params list of match expression parameter values indexed by parameter placeholders. For example, [':name' => 'Dan', ':age' => 31]. These parameters will be automatically escaped using [[Connection::escapeMatchValue()]] and inserted into MATCH expression as a quoted strings.

Открытые методы

Метод Описание
__construct ( string $match = null, array $params = [], array $config = [] ) Constructor.
addParams ( array $params ) Adds additional parameters to be parsed into the query.
andMatch ( string | array | yii\db\Expression $condition, array $params = [] ) Adds an additional MATCH condition to the existing one.
match ( string | array | yii\db\Expression $condition, array $params = [] ) Sets the MATCH expression.
orMatch ( string | array | yii\db\Expression $condition, array $params = [] ) Adds an additional MATCH condition to the existing one.
params ( array $params ) Sets the parameters to be parsed into the query.

Описание методов

__construct() публичный Метод

Constructor.
public __construct ( string $match = null, array $params = [], array $config = [] )
$match string the MATCH expression
$params array expression parameters.
$config array name-value pairs that will be used to initialize the object properties

addParams() публичный Метод

Adds additional parameters to be parsed into the query.
См. также: params()
public addParams ( array $params )
$params array list of expression parameter values indexed by parameter placeholders. For example, `[':name' => 'Dan', ':age' => 31]`.

andMatch() публичный Метод

The new condition and the existing one will be joined using the 'AND' (' ') operator.
См. также: match()
См. также: orMatch()
public andMatch ( string | array | yii\db\Expression $condition, array $params = [] )
$condition string | array | yii\db\Expression the new MATCH condition. Please refer to [[match()]] on how to specify this parameter.
$params array the parameters (name => value) to be parsed into the query.

match() публичный Метод

The method requires a $condition parameter, and optionally a $params parameter specifying the values to be parsed into the expression. The $condition parameter should be either a string (e.g. '@name "John"') or an array.
См. также: andMatch()
См. также: orMatch()
public match ( string | array | yii\db\Expression $condition, array $params = [] )
$condition string | array | yii\db\Expression the conditions that should be put in the MATCH expression.
$params array the parameters (name => value) to be parsed into the query.

orMatch() публичный Метод

The new condition and the existing one will be joined using the 'OR' ('|') operator.
См. также: match()
См. также: andMatch()
public orMatch ( string | array | yii\db\Expression $condition, array $params = [] )
$condition string | array | yii\db\Expression the new WHERE condition. Please refer to [[match()]] on how to specify this parameter.
$params array the parameters (name => value) to be parsed into the query.

params() публичный Метод

Sets the parameters to be parsed into the query.
См. также: addParams()
public params ( array $params )
$params array list of expression parameter values indexed by parameter placeholders. For example, `[':name' => 'Dan', ':age' => 31]`.

Описание свойств

$match публичное свойство

MATCH expression. For example: ['title' => 'Yii', 'content' => 'Sphinx']. Note: being specified as a plain string this value will not be quoted or escaped, do not pass possible unsecured values (like the ones obtained from HTTP request) as a direct value.
См. также: match()
public $match

$params публичное свойство

list of match expression parameter values indexed by parameter placeholders. For example, [':name' => 'Dan', ':age' => 31]. These parameters will be automatically escaped using [[Connection::escapeMatchValue()]] and inserted into MATCH expression as a quoted strings.
public $params