Class yii\mongodb\file\Query
Inheritance | yii\mongodb\file\Query » yii\mongodb\Query » yii\base\Component |
---|---|
Implements | yii\db\QueryInterface |
Uses Traits | yii\db\QueryTrait |
Subclasses | yii\mongodb\file\ActiveQuery |
Available since extension's version | 2.0 |
Source Code | https://github.com/yiisoft/yii2-mongodb/blob/master/file/Query.php |
Query represents Mongo "find" operation for GridFS collection.
Query behaves exactly as regular yii\mongodb\Query. Found files will be represented as arrays of file document attributes with additional 'file' key, which stores \MongoGridFSFile instance.
Public Properties
Property | Type | Description | Defined By |
---|---|---|---|
$collection | yii\mongodb\file\Collection | Collection instance. | yii\mongodb\file\Query |
$from | string|array | The collection to be selected from. | yii\mongodb\Query |
$options | array | Cursor options in format: optionKey => optionValue | yii\mongodb\Query |
$select | array | The fields of the results to return. | yii\mongodb\Query |
Public Methods
Method | Description | Defined By |
---|---|---|
addOptions() | Adds additional cursor options. | yii\mongodb\Query |
all() | Executes the query and returns all results as an array. | yii\mongodb\Query |
andFilterCompare() | Helper method for easy querying on values containing some common operators. | yii\mongodb\Query |
average() | Returns the average of the specified column values. | yii\mongodb\Query |
count() | Returns the number of records. | yii\mongodb\Query |
distinct() | Returns a list of distinct values for the given column across a collection. | yii\mongodb\Query |
exists() | Returns a value indicating whether the query result contains any row of data. | yii\mongodb\Query |
from() | Sets the collection to be selected from. | yii\mongodb\Query |
getCollection() | Returns the Mongo collection for this query. | yii\mongodb\file\Query |
max() | Returns the maximum of the specified column values. | yii\mongodb\Query |
min() | Returns the minimum of the specified column values. | yii\mongodb\Query |
modify() | Performs 'findAndModify' query and returns a single row of result. | yii\mongodb\Query |
one() | Executes the query and returns a single row of result. | yii\mongodb\file\Query |
options() | Sets the cursor options. | yii\mongodb\Query |
populate() | Converts the raw query results into the format as specified by this query. | yii\mongodb\file\Query |
select() | Sets the list of fields of the results to return. | yii\mongodb\Query |
sum() | Returns the sum of the specified column values. | yii\mongodb\Query |
Protected Methods
Method | Description | Defined By |
---|---|---|
aggregate() | Performs the aggregation for the given column. | yii\mongodb\Query |
buildCursor() | Builds the Mongo cursor for this query. | yii\mongodb\Query |
fetchRows() | Fetches rows from the given Mongo cursor. | yii\mongodb\Query |
fetchRowsInternal() | yii\mongodb\Query |
Property Details
Collection instance. This property is read-only.
Method Details
public $this addOptions ( $options ) | ||
$options | array |
Cursor options in format: optionName => optionValue |
return | $this |
The query object itself |
---|
public function addOptions($options)
{
if (is_array($this->options)) {
$this->options = array_merge($this->options, $options);
} else {
$this->options = $options;
}
return $this;
}
Defined in: yii\mongodb\Query::aggregate()
Performs the aggregation for the given column.
protected integer aggregate ( $column, $operator, $db ) | ||
$column | string |
Column name. |
$operator | string |
Aggregation operator. |
$db | yii\mongodb\Connection |
The database connection used to execute the query. |
return | integer |
Aggregation result. |
---|
protected function aggregate($column, $operator, $db)
{
$collection = $this->getCollection($db);
$pipelines = [];
if ($this->where !== null) {
$pipelines[] = ['$match' => $collection->buildCondition($this->where)];
}
$pipelines[] = [
'$group' => [
'_id' => '1',
'total' => [
'$' . $operator => '$' . $column
],
]
];
$result = $collection->aggregate($pipelines);
if (array_key_exists(0, $result)) {
return $result[0]['total'];
} else {
return 0;
}
}
Defined in: yii\mongodb\Query::all()
Executes the query and returns all results as an array.
public array all ( $db = null ) | ||
$db | yii\mongodb\Connection |
The Mongo connection used to execute the query.
If this parameter is not given, the |
return | array |
The query results. If the query results in nothing, an empty array will be returned. |
---|
public function all($db = null)
{
$cursor = $this->buildCursor($db);
$rows = $this->fetchRows($cursor, true, $this->indexBy);
return $this->populate($rows);
}
Defined in: yii\mongodb\Query::andFilterCompare()
Helper method for easy querying on values containing some common operators.
The comparison operator is intelligently determined based on the first few characters in the given value and internally translated to a MongoDB operator. In particular, it recognizes the following operators if they appear as the leading characters in the given value: <: the column must be less than the given value ($lt). >: the column must be greater than the given value ($gt). <=: the column must be less than or equal to the given value ($lte). >=: the column must be greater than or equal to the given value ($gte). <>: the column must not be the same as the given value ($ne). Note that when $partialMatch is true, this would mean the value must not be a substring of the column. =: the column must be equal to the given value ($eq). none of the above: use the $defaultOperator
Note that when the value is empty, no comparison expression will be added to the search condition.
See also \yii\mongodb\yii\mongodb\Collection::buildCondition().
public $this andFilterCompare ( $name, $value, $defaultOperator = '=' ) | ||
$name | string |
Column name |
$value | string |
Column value |
$defaultOperator | string |
Defaults to =, performing an exact match. For example: use 'LIKE' or 'REGEX' for partial cq regex matching |
return | $this |
The query object itself. |
---|
public function andFilterCompare($name, $value, $defaultOperator = '=')
{
$matches = [];
if (preg_match('/^(<>|>=|>|<=|<|=)/', $value, $matches)) {
$op = $matches[1];
$value = substr($value, strlen($op));
} else {
$op = $defaultOperator;
}
return $this->andFilterWhere([$op, $name, $value]);
}
Defined in: yii\mongodb\Query::average()
Returns the average of the specified column values.
public integer average ( $q, $db = null ) | ||
$q | string |
The column name. Make sure you properly quote column names in the expression. |
$db | yii\mongodb\Connection |
The Mongo connection used to execute the query.
If this parameter is not given, the |
return | integer |
The average of the specified column values. |
---|
public function average($q, $db = null)
{
return $this->aggregate($q, 'avg', $db);
}
Defined in: yii\mongodb\Query::buildCursor()
Builds the Mongo cursor for this query.
protected \MongoCursor buildCursor ( $db = null ) | ||
$db | yii\mongodb\Connection |
The database connection used to execute the query. |
return | \MongoCursor |
Mongo cursor instance. |
---|
protected function buildCursor($db = null)
{
$cursor = $this->getCollection($db)->find($this->composeCondition(), $this->composeSelectFields());
if (!empty($this->orderBy)) {
$cursor->sort($this->composeSort());
}
$cursor->limit($this->limit);
$cursor->skip($this->offset);
foreach ($this->options as $key => $value) {
$cursor->addOption($key, $value);
}
return $cursor;
}
Defined in: yii\mongodb\Query::count()
Returns the number of records.
public integer count ( $q = '*', $db = null ) | ||
$q | string |
Kept to match QueryInterface, its value is ignored. |
$db | yii\mongodb\Connection |
The Mongo connection used to execute the query.
If this parameter is not given, the |
return | integer |
Number of records |
---|---|---|
throws | yii\mongodb\Exception |
on failure. |
public function count($q = '*', $db = null)
{
$cursor = $this->buildCursor($db);
$token = 'find.count(' . Json::encode($cursor->info()) . ')';
Yii::info($token, __METHOD__);
try {
Yii::beginProfile($token, __METHOD__);
$result = $cursor->count();
Yii::endProfile($token, __METHOD__);
return $result;
} catch (\Exception $e) {
Yii::endProfile($token, __METHOD__);
throw new Exception($e->getMessage(), (int) $e->getCode(), $e);
}
}
Defined in: yii\mongodb\Query::distinct()
Returns a list of distinct values for the given column across a collection.
public array distinct ( $q, $db = null ) | ||
$q | string |
Column to use. |
$db | yii\mongodb\Connection |
The Mongo connection used to execute the query.
If this parameter is not given, the |
return | array |
Array of distinct values |
---|
public function distinct($q, $db = null)
{
$collection = $this->getCollection($db);
if ($this->where !== null) {
$condition = $this->where;
} else {
$condition = [];
}
$result = $collection->distinct($q, $condition);
if ($result === false) {
return [];
} else {
return $result;
}
}
Defined in: yii\mongodb\Query::exists()
Returns a value indicating whether the query result contains any row of data.
public boolean exists ( $db = null ) | ||
$db | yii\mongodb\Connection |
The Mongo connection used to execute the query.
If this parameter is not given, the |
return | boolean |
Whether the query result contains any row of data. |
---|
public function exists($db = null)
{
return $this->one($db) !== null;
}
Defined in: yii\mongodb\Query::fetchRows()
Fetches rows from the given Mongo cursor.
protected array|boolean fetchRows ( $cursor, $all = true, $indexBy = null ) | ||
$cursor | \MongoCursor |
Mongo cursor instance to fetch data from. |
$all | boolean |
Whether to fetch all rows or only first one. |
$indexBy | string|callable |
The column name or PHP callback, by which the query results should be indexed by. |
return | array|boolean |
Result. |
---|---|---|
throws | yii\mongodb\Exception |
on failure. |
protected function fetchRows($cursor, $all = true, $indexBy = null)
{
$token = 'find(' . Json::encode($cursor->info()) . ')';
Yii::info($token, __METHOD__);
try {
Yii::beginProfile($token, __METHOD__);
$result = $this->fetchRowsInternal($cursor, $all, $indexBy);
Yii::endProfile($token, __METHOD__);
return $result;
} catch (\Exception $e) {
Yii::endProfile($token, __METHOD__);
throw new Exception($e->getMessage(), (int) $e->getCode(), $e);
}
}
protected array|boolean fetchRowsInternal ( $cursor, $all, $indexBy ) | ||
$cursor | \MongoCursor |
Mongo cursor instance to fetch data from. |
$all | boolean |
Whether to fetch all rows or only first one. |
$indexBy | string|callable |
Value to index by. |
return | array|boolean |
Result. |
---|
protected function fetchRowsInternal($cursor, $all, $indexBy)
{
$result = [];
if ($all) {
foreach ($cursor as $row) {
$result[] = $row;
}
} else {
if ($row = $cursor->getNext()) {
$result = $row;
} else {
$result = false;
}
}
return $result;
}
Defined in: yii\mongodb\Query::from()
Sets the collection to be selected from.
public $this from ( $collection ) | ||
$collection | ||
return | $this |
The query object itself. |
---|
public function from($collection)
{
$this->from = $collection;
return $this;
}
Returns the Mongo collection for this query.
public yii\mongodb\file\Collection getCollection ( $db = null ) | ||
$db | yii\mongodb\Connection |
Mongo connection. |
return | yii\mongodb\file\Collection |
Collection instance. |
---|
public function getCollection($db = null)
{
if ($db === null) {
$db = Yii::$app->get('mongodb');
}
return $db->getFileCollection($this->from);
}
Defined in: yii\mongodb\Query::max()
Returns the maximum of the specified column values.
public integer max ( $q, $db = null ) | ||
$q | string |
The column name. Make sure you properly quote column names in the expression. |
$db | yii\mongodb\Connection |
The Mongo connection used to execute the query.
If this parameter is not given, the |
return | integer |
The maximum of the specified column values. |
---|
public function max($q, $db = null)
{
return $this->aggregate($q, 'max', $db);
}
Defined in: yii\mongodb\Query::min()
Returns the minimum of the specified column values.
public integer min ( $q, $db = null ) | ||
$q | string |
The column name. Make sure you properly quote column names in the expression. |
$db | yii\mongodb\Connection |
The database connection used to generate the SQL statement.
If this parameter is not given, the |
return | integer |
The minimum of the specified column values. |
---|
public function min($q, $db = null)
{
return $this->aggregate($q, 'min', $db);
}
Defined in: yii\mongodb\Query::modify()
Performs 'findAndModify' query and returns a single row of result.
public array|null modify ( $update, $options = [], $db = null ) | ||
$update | array |
Update criteria |
$options | array |
List of options in format: optionName => optionValue. |
$db | yii\mongodb\Connection |
The Mongo connection used to execute the query. |
return | array|null |
The original document, or the modified document when $options['new'] is set. |
---|
public function modify($update, $options = [], $db = null)
{
$collection = $this->getCollection($db);
if (!empty($this->orderBy)) {
$options['sort'] = $this->composeSort();
}
return $collection->findAndModify($this->composeCondition(), $update, $this->composeSelectFields(), $options);
}
Executes the query and returns a single row of result.
public array|boolean one ( $db = null ) | ||
$db | yii\mongodb\Connection |
The Mongo connection used to execute the query.
If this parameter is not given, the |
return | array|boolean |
The first row (in terms of an array) of the query result. False is returned if the query results in nothing. |
---|
public function one($db = null)
{
$row = parent::one($db);
if ($row !== false) {
$models = $this->populate([$row]);
return reset($models) ?: null;
} else {
return null;
}
}
public $this options ( $options ) | ||
$options | array |
Cursor options in format: optionName => optionValue |
return | $this |
The query object itself |
---|
public function options($options)
{
$this->options = $options;
return $this;
}
Converts the raw query results into the format as specified by this query.
This method is internally used to convert the data fetched from database into the format as required by this query.
public array populate ( $rows ) | ||
$rows | array |
The raw query result from database |
return | array |
The converted query result |
---|
public function populate($rows)
{
$result = [];
foreach ($rows as $file) {
$row = $file->file;
$row['file'] = $file;
$result[] = $row;
}
return parent::populate($result);
}
Defined in: yii\mongodb\Query::select()
Sets the list of fields of the results to return.
public $this select ( array $fields ) | ||
$fields | array |
Fields of the results to return. |
return | $this |
The query object itself. |
---|
public function select(array $fields)
{
$this->select = $fields;
return $this;
}
Defined in: yii\mongodb\Query::sum()
Returns the sum of the specified column values.
public integer sum ( $q, $db = null ) | ||
$q | string |
The column name. Make sure you properly quote column names in the expression. |
$db | yii\mongodb\Connection |
The Mongo connection used to execute the query.
If this parameter is not given, the |
return | integer |
The sum of the specified column values |
---|
public function sum($q, $db = null)
{
return $this->aggregate($q, 'sum', $db);
}