composer update
This commit is contained in:
		| @@ -1,46 +1,25 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Query\Expression; | ||||
|  | ||||
| use Countable; | ||||
| use function count; | ||||
| use function implode; | ||||
|  | ||||
| /** | ||||
|  * Composite expression is responsible to build a group of similar expression. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.1 | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class CompositeExpression implements \Countable | ||||
| class CompositeExpression implements Countable | ||||
| { | ||||
|     /** | ||||
|      * Constant that represents an AND composite expression. | ||||
|      */ | ||||
|     const TYPE_AND = 'AND'; | ||||
|     public const TYPE_AND = 'AND'; | ||||
|  | ||||
|     /** | ||||
|      * Constant that represents an OR composite expression. | ||||
|      */ | ||||
|     const TYPE_OR  = 'OR'; | ||||
|     public const TYPE_OR = 'OR'; | ||||
|  | ||||
|     /** | ||||
|      * The instance type of composite expression. | ||||
| @@ -52,15 +31,13 @@ class CompositeExpression implements \Countable | ||||
|     /** | ||||
|      * Each expression part of the composite expression. | ||||
|      * | ||||
|      * @var array | ||||
|      * @var self[]|string[] | ||||
|      */ | ||||
|     private $parts = []; | ||||
|  | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param string $type  Instance type of composite expression. | ||||
|      * @param array  $parts Composition of expressions to be joined on composite expression. | ||||
|      * @param string          $type  Instance type of composite expression. | ||||
|      * @param self[]|string[] $parts Composition of expressions to be joined on composite expression. | ||||
|      */ | ||||
|     public function __construct($type, array $parts = []) | ||||
|     { | ||||
| @@ -72,7 +49,7 @@ class CompositeExpression implements \Countable | ||||
|     /** | ||||
|      * Adds multiple parts to composite expression. | ||||
|      * | ||||
|      * @param array $parts | ||||
|      * @param self[]|string[] $parts | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Query\Expression\CompositeExpression | ||||
|      */ | ||||
| @@ -98,7 +75,7 @@ class CompositeExpression implements \Countable | ||||
|             return $this; | ||||
|         } | ||||
|  | ||||
|         if ($part instanceof self && 0 === count($part)) { | ||||
|         if ($part instanceof self && count($part) === 0) { | ||||
|             return $this; | ||||
|         } | ||||
|  | ||||
|   | ||||
| @@ -1,21 +1,4 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Query\Expression; | ||||
|  | ||||
| @@ -28,32 +11,27 @@ use function sprintf; | ||||
|  | ||||
| /** | ||||
|  * ExpressionBuilder class is responsible to dynamically create SQL query parts. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.1 | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class ExpressionBuilder | ||||
| { | ||||
|     const EQ  = '='; | ||||
|     const NEQ = '<>'; | ||||
|     const LT  = '<'; | ||||
|     const LTE = '<='; | ||||
|     const GT  = '>'; | ||||
|     const GTE = '>='; | ||||
|     public const EQ  = '='; | ||||
|     public const NEQ = '<>'; | ||||
|     public const LT  = '<'; | ||||
|     public const LTE = '<='; | ||||
|     public const GT  = '>'; | ||||
|     public const GTE = '>='; | ||||
|  | ||||
|     /** | ||||
|      * The DBAL Connection. | ||||
|      * | ||||
|      * @var \Doctrine\DBAL\Connection | ||||
|      * @var Connection | ||||
|      */ | ||||
|     private $connection; | ||||
|  | ||||
|     /** | ||||
|      * Initializes a new <tt>ExpressionBuilder</tt>. | ||||
|      * | ||||
|      * @param \Doctrine\DBAL\Connection $connection The DBAL Connection. | ||||
|      * @param Connection $connection The DBAL Connection. | ||||
|      */ | ||||
|     public function __construct(Connection $connection) | ||||
|     { | ||||
| @@ -72,7 +50,7 @@ class ExpressionBuilder | ||||
|      * @param mixed $x Optional clause. Defaults = null, but requires | ||||
|      *                 at least one defined when converting to string. | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Query\Expression\CompositeExpression | ||||
|      * @return CompositeExpression | ||||
|      */ | ||||
|     public function andX($x = null) | ||||
|     { | ||||
| @@ -91,7 +69,7 @@ class ExpressionBuilder | ||||
|      * @param mixed $x Optional clause. Defaults = null, but requires | ||||
|      *                 at least one defined when converting to string. | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Query\Expression\CompositeExpression | ||||
|      * @return CompositeExpression | ||||
|      */ | ||||
|     public function orX($x = null) | ||||
|     { | ||||
| @@ -282,27 +260,27 @@ class ExpressionBuilder | ||||
|     /** | ||||
|      * Creates a IN () comparison expression with the given arguments. | ||||
|      * | ||||
|      * @param string       $x The field in string format to be inspected by IN() comparison. | ||||
|      * @param string|array $y The placeholder or the array of values to be used by IN() comparison. | ||||
|      * @param string          $x The field in string format to be inspected by IN() comparison. | ||||
|      * @param string|string[] $y The placeholder or the array of values to be used by IN() comparison. | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function in($x, $y) | ||||
|     { | ||||
|         return $this->comparison($x, 'IN', '('.implode(', ', (array) $y).')'); | ||||
|         return $this->comparison($x, 'IN', '(' . implode(', ', (array) $y) . ')'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Creates a NOT IN () comparison expression with the given arguments. | ||||
|      * | ||||
|      * @param string       $x The field in string format to be inspected by NOT IN() comparison. | ||||
|      * @param string|array $y The placeholder or the array of values to be used by NOT IN() comparison. | ||||
|      * @param string          $x The field in string format to be inspected by NOT IN() comparison. | ||||
|      * @param string|string[] $y The placeholder or the array of values to be used by NOT IN() comparison. | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function notIn($x, $y) | ||||
|     { | ||||
|         return $this->comparison($x, 'NOT IN', '('.implode(', ', (array) $y).')'); | ||||
|         return $this->comparison($x, 'NOT IN', '(' . implode(', ', (array) $y) . ')'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|   | ||||
| @@ -1,27 +1,12 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Query; | ||||
|  | ||||
| use Doctrine\DBAL\Connection; | ||||
| use Doctrine\DBAL\Driver\Statement; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use Doctrine\DBAL\Query\Expression\CompositeExpression; | ||||
| use Doctrine\DBAL\Connection; | ||||
| use Doctrine\DBAL\Query\Expression\ExpressionBuilder; | ||||
| use function array_key_exists; | ||||
| use function array_keys; | ||||
| use function array_unshift; | ||||
| @@ -29,7 +14,6 @@ use function func_get_args; | ||||
| use function func_num_args; | ||||
| use function implode; | ||||
| use function is_array; | ||||
| use function is_null; | ||||
| use function is_object; | ||||
| use function key; | ||||
| use function strtoupper; | ||||
| @@ -44,37 +28,34 @@ use function substr; | ||||
|  * The query builder does no validation whatsoever if certain features even work with the | ||||
|  * underlying database vendor. Limit queries and joins are NOT applied to UPDATE and DELETE statements | ||||
|  * even if some vendors such as MySQL support it. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.1 | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class QueryBuilder | ||||
| { | ||||
|     /* | ||||
|      * The query types. | ||||
|      */ | ||||
|     const SELECT = 0; | ||||
|     const DELETE = 1; | ||||
|     const UPDATE = 2; | ||||
|     const INSERT = 3; | ||||
|     public const SELECT = 0; | ||||
|     public const DELETE = 1; | ||||
|     public const UPDATE = 2; | ||||
|     public const INSERT = 3; | ||||
|  | ||||
|     /* | ||||
|      * The builder states. | ||||
|      */ | ||||
|     const STATE_DIRTY = 0; | ||||
|     const STATE_CLEAN = 1; | ||||
|     public const STATE_DIRTY = 0; | ||||
|     public const STATE_CLEAN = 1; | ||||
|  | ||||
|     /** | ||||
|      * The DBAL Connection. | ||||
|      * | ||||
|      * @var \Doctrine\DBAL\Connection | ||||
|      * @var Connection | ||||
|      */ | ||||
|     private $connection; | ||||
|  | ||||
|     /** | ||||
|      * @var array The array of SQL parts collected. | ||||
|      * The array of SQL parts collected. | ||||
|      * | ||||
|      * @var mixed[] | ||||
|      */ | ||||
|     private $sqlParts = [ | ||||
|         'select'  => [], | ||||
| @@ -98,14 +79,14 @@ class QueryBuilder | ||||
|     /** | ||||
|      * The query parameters. | ||||
|      * | ||||
|      * @var array | ||||
|      * @var mixed[] | ||||
|      */ | ||||
|     private $params = []; | ||||
|  | ||||
|     /** | ||||
|      * The parameter type map of this query. | ||||
|      * | ||||
|      * @var array | ||||
|      * @var int[]|string[] | ||||
|      */ | ||||
|     private $paramTypes = []; | ||||
|  | ||||
| @@ -147,7 +128,7 @@ class QueryBuilder | ||||
|     /** | ||||
|      * Initializes a new <tt>QueryBuilder</tt>. | ||||
|      * | ||||
|      * @param \Doctrine\DBAL\Connection $connection The DBAL Connection. | ||||
|      * @param Connection $connection The DBAL Connection. | ||||
|      */ | ||||
|     public function __construct(Connection $connection) | ||||
|     { | ||||
| @@ -168,7 +149,7 @@ class QueryBuilder | ||||
|      * For more complex expression construction, consider storing the expression | ||||
|      * builder object in a local variable. | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Query\Expression\ExpressionBuilder | ||||
|      * @return ExpressionBuilder | ||||
|      */ | ||||
|     public function expr() | ||||
|     { | ||||
| @@ -188,7 +169,7 @@ class QueryBuilder | ||||
|     /** | ||||
|      * Gets the associated DBAL Connection for this query builder. | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Connection | ||||
|      * @return Connection | ||||
|      */ | ||||
|     public function getConnection() | ||||
|     { | ||||
| @@ -211,11 +192,11 @@ class QueryBuilder | ||||
|      * Uses {@see Connection::executeQuery} for select statements and {@see Connection::executeUpdate} | ||||
|      * for insert, update and delete statements. | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Driver\Statement|int | ||||
|      * @return Statement|int | ||||
|      */ | ||||
|     public function execute() | ||||
|     { | ||||
|         if ($this->type == self::SELECT) { | ||||
|         if ($this->type === self::SELECT) { | ||||
|             return $this->connection->executeQuery($this->getSQL(), $this->params, $this->paramTypes); | ||||
|         } | ||||
|  | ||||
| @@ -259,7 +240,7 @@ class QueryBuilder | ||||
|         } | ||||
|  | ||||
|         $this->state = self::STATE_CLEAN; | ||||
|         $this->sql = $sql; | ||||
|         $this->sql   = $sql; | ||||
|  | ||||
|         return $sql; | ||||
|     } | ||||
| @@ -306,15 +287,15 @@ class QueryBuilder | ||||
|      *         )); | ||||
|      * </code> | ||||
|      * | ||||
|      * @param array $params The query parameters to set. | ||||
|      * @param array $types  The query parameters types to set. | ||||
|      * @param mixed[]        $params The query parameters to set. | ||||
|      * @param int[]|string[] $types  The query parameters types to set. | ||||
|      * | ||||
|      * @return $this This QueryBuilder instance. | ||||
|      */ | ||||
|     public function setParameters(array $params, array $types = []) | ||||
|     { | ||||
|         $this->paramTypes = $types; | ||||
|         $this->params = $params; | ||||
|         $this->params     = $params; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
| @@ -322,7 +303,7 @@ class QueryBuilder | ||||
|     /** | ||||
|      * Gets all defined query parameters for the query being constructed indexed by parameter index or name. | ||||
|      * | ||||
|      * @return array The currently defined query parameters indexed by parameter index or name. | ||||
|      * @return mixed[] The currently defined query parameters indexed by parameter index or name. | ||||
|      */ | ||||
|     public function getParameters() | ||||
|     { | ||||
| @@ -344,7 +325,7 @@ class QueryBuilder | ||||
|     /** | ||||
|      * Gets all defined query parameter types for the query being constructed indexed by parameter index or name. | ||||
|      * | ||||
|      * @return array The currently defined query parameter types indexed by parameter index or name. | ||||
|      * @return int[]|string[] The currently defined query parameter types indexed by parameter index or name. | ||||
|      */ | ||||
|     public function getParameterTypes() | ||||
|     { | ||||
| @@ -372,7 +353,7 @@ class QueryBuilder | ||||
|      */ | ||||
|     public function setFirstResult($firstResult) | ||||
|     { | ||||
|         $this->state = self::STATE_DIRTY; | ||||
|         $this->state       = self::STATE_DIRTY; | ||||
|         $this->firstResult = $firstResult; | ||||
|  | ||||
|         return $this; | ||||
| @@ -398,7 +379,7 @@ class QueryBuilder | ||||
|      */ | ||||
|     public function setMaxResults($maxResults) | ||||
|     { | ||||
|         $this->state = self::STATE_DIRTY; | ||||
|         $this->state      = self::STATE_DIRTY; | ||||
|         $this->maxResults = $maxResults; | ||||
|  | ||||
|         return $this; | ||||
| @@ -429,22 +410,22 @@ class QueryBuilder | ||||
|      */ | ||||
|     public function add($sqlPartName, $sqlPart, $append = false) | ||||
|     { | ||||
|         $isArray = is_array($sqlPart); | ||||
|         $isArray    = is_array($sqlPart); | ||||
|         $isMultiple = is_array($this->sqlParts[$sqlPartName]); | ||||
|  | ||||
|         if ($isMultiple && !$isArray) { | ||||
|         if ($isMultiple && ! $isArray) { | ||||
|             $sqlPart = [$sqlPart]; | ||||
|         } | ||||
|  | ||||
|         $this->state = self::STATE_DIRTY; | ||||
|  | ||||
|         if ($append) { | ||||
|             if ($sqlPartName == "orderBy" || $sqlPartName == "groupBy" || $sqlPartName == "select" || $sqlPartName == "set") { | ||||
|             if ($sqlPartName === 'orderBy' || $sqlPartName === 'groupBy' || $sqlPartName === 'select' || $sqlPartName === 'set') { | ||||
|                 foreach ($sqlPart as $part) { | ||||
|                     $this->sqlParts[$sqlPartName][] = $part; | ||||
|                 } | ||||
|             } elseif ($isArray && is_array($sqlPart[key($sqlPart)])) { | ||||
|                 $key = key($sqlPart); | ||||
|                 $key                                  = key($sqlPart); | ||||
|                 $this->sqlParts[$sqlPartName][$key][] = $sqlPart[$key]; | ||||
|             } elseif ($isMultiple) { | ||||
|                 $this->sqlParts[$sqlPartName][] = $sqlPart; | ||||
| @@ -536,13 +517,13 @@ class QueryBuilder | ||||
|     { | ||||
|         $this->type = self::DELETE; | ||||
|  | ||||
|         if ( ! $delete) { | ||||
|         if (! $delete) { | ||||
|             return $this; | ||||
|         } | ||||
|  | ||||
|         return $this->add('from', [ | ||||
|             'table' => $delete, | ||||
|             'alias' => $alias | ||||
|             'alias' => $alias, | ||||
|         ]); | ||||
|     } | ||||
|  | ||||
| @@ -552,9 +533,9 @@ class QueryBuilder | ||||
|      * | ||||
|      * <code> | ||||
|      *     $qb = $conn->createQueryBuilder() | ||||
|      *         ->update('users', 'u') | ||||
|      *         ->set('u.last_login', 'NOW()') | ||||
|      *         ->where('u.id = ?'); | ||||
|      *         ->update('counters', 'c') | ||||
|      *         ->set('c.value', 'c.value + 1') | ||||
|      *         ->where('c.id = ?'); | ||||
|      * </code> | ||||
|      * | ||||
|      * @param string $update The table whose rows are subject to the update. | ||||
| @@ -566,13 +547,13 @@ class QueryBuilder | ||||
|     { | ||||
|         $this->type = self::UPDATE; | ||||
|  | ||||
|         if ( ! $update) { | ||||
|         if (! $update) { | ||||
|             return $this; | ||||
|         } | ||||
|  | ||||
|         return $this->add('from', [ | ||||
|             'table' => $update, | ||||
|             'alias' => $alias | ||||
|             'alias' => $alias, | ||||
|         ]); | ||||
|     } | ||||
|  | ||||
| @@ -599,13 +580,11 @@ class QueryBuilder | ||||
|     { | ||||
|         $this->type = self::INSERT; | ||||
|  | ||||
|         if ( ! $insert) { | ||||
|         if (! $insert) { | ||||
|             return $this; | ||||
|         } | ||||
|  | ||||
|         return $this->add('from', [ | ||||
|             'table' => $insert | ||||
|         ]); | ||||
|         return $this->add('from', ['table' => $insert]); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -627,7 +606,7 @@ class QueryBuilder | ||||
|     { | ||||
|         return $this->add('from', [ | ||||
|             'table' => $from, | ||||
|             'alias' => $alias | ||||
|             'alias' => $alias, | ||||
|         ], true); | ||||
|     } | ||||
|  | ||||
| @@ -677,8 +656,8 @@ class QueryBuilder | ||||
|                 'joinType'      => 'inner', | ||||
|                 'joinTable'     => $join, | ||||
|                 'joinAlias'     => $alias, | ||||
|                 'joinCondition' => $condition | ||||
|             ] | ||||
|                 'joinCondition' => $condition, | ||||
|             ], | ||||
|         ], true); | ||||
|     } | ||||
|  | ||||
| @@ -706,8 +685,8 @@ class QueryBuilder | ||||
|                 'joinType'      => 'left', | ||||
|                 'joinTable'     => $join, | ||||
|                 'joinAlias'     => $alias, | ||||
|                 'joinCondition' => $condition | ||||
|             ] | ||||
|                 'joinCondition' => $condition, | ||||
|             ], | ||||
|         ], true); | ||||
|     } | ||||
|  | ||||
| @@ -735,8 +714,8 @@ class QueryBuilder | ||||
|                 'joinType'      => 'right', | ||||
|                 'joinTable'     => $join, | ||||
|                 'joinAlias'     => $alias, | ||||
|                 'joinCondition' => $condition | ||||
|             ] | ||||
|                 'joinCondition' => $condition, | ||||
|             ], | ||||
|         ], true); | ||||
|     } | ||||
|  | ||||
| @@ -745,9 +724,9 @@ class QueryBuilder | ||||
|      * | ||||
|      * <code> | ||||
|      *     $qb = $conn->createQueryBuilder() | ||||
|      *         ->update('users', 'u') | ||||
|      *         ->set('u.last_login', 'NOW()') | ||||
|      *         ->where('u.id = ?'); | ||||
|      *         ->update('counters', 'c') | ||||
|      *         ->set('c.value', 'c.value + 1') | ||||
|      *         ->where('c.id = ?'); | ||||
|      * </code> | ||||
|      * | ||||
|      * @param string $key   The column to set. | ||||
| @@ -757,7 +736,7 @@ class QueryBuilder | ||||
|      */ | ||||
|     public function set($key, $value) | ||||
|     { | ||||
|         return $this->add('set', $key .' = ' . $value, true); | ||||
|         return $this->add('set', $key . ' = ' . $value, true); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -766,19 +745,19 @@ class QueryBuilder | ||||
|      * | ||||
|      * <code> | ||||
|      *     $qb = $conn->createQueryBuilder() | ||||
|      *         ->select('u.name') | ||||
|      *         ->from('users', 'u') | ||||
|      *         ->where('u.id = ?'); | ||||
|      *         ->select('c.value') | ||||
|      *         ->from('counters', 'c') | ||||
|      *         ->where('c.id = ?'); | ||||
|      * | ||||
|      *     // You can optionally programatically build and/or expressions | ||||
|      *     $qb = $conn->createQueryBuilder(); | ||||
|      * | ||||
|      *     $or = $qb->expr()->orx(); | ||||
|      *     $or->add($qb->expr()->eq('u.id', 1)); | ||||
|      *     $or->add($qb->expr()->eq('u.id', 2)); | ||||
|      *     $or->add($qb->expr()->eq('c.id', 1)); | ||||
|      *     $or->add($qb->expr()->eq('c.id', 2)); | ||||
|      * | ||||
|      *     $qb->update('users', 'u') | ||||
|      *         ->set('u.last_login', 'NOW()') | ||||
|      *     $qb->update('counters', 'c') | ||||
|      *         ->set('c.value', 'c.value + 1') | ||||
|      *         ->where($or); | ||||
|      * </code> | ||||
|      * | ||||
| @@ -788,7 +767,7 @@ class QueryBuilder | ||||
|      */ | ||||
|     public function where($predicates) | ||||
|     { | ||||
|         if ( ! (func_num_args() == 1 && $predicates instanceof CompositeExpression)) { | ||||
|         if (! (func_num_args() === 1 && $predicates instanceof CompositeExpression)) { | ||||
|             $predicates = new CompositeExpression(CompositeExpression::TYPE_AND, func_get_args()); | ||||
|         } | ||||
|  | ||||
| @@ -807,15 +786,15 @@ class QueryBuilder | ||||
|      *         ->andWhere('u.is_active = 1'); | ||||
|      * </code> | ||||
|      * | ||||
|      * @see where() | ||||
|      * | ||||
|      * @param mixed $where The query restrictions. | ||||
|      * | ||||
|      * @return $this This QueryBuilder instance. | ||||
|      * | ||||
|      * @see where() | ||||
|      */ | ||||
|     public function andWhere($where) | ||||
|     { | ||||
|         $args = func_get_args(); | ||||
|         $args  = func_get_args(); | ||||
|         $where = $this->getQueryPart('where'); | ||||
|  | ||||
|         if ($where instanceof CompositeExpression && $where->getType() === CompositeExpression::TYPE_AND) { | ||||
| @@ -840,15 +819,15 @@ class QueryBuilder | ||||
|      *         ->orWhere('u.id = 2'); | ||||
|      * </code> | ||||
|      * | ||||
|      * @see where() | ||||
|      * | ||||
|      * @param mixed $where The WHERE statement. | ||||
|      * | ||||
|      * @return $this This QueryBuilder instance. | ||||
|      * | ||||
|      * @see where() | ||||
|      */ | ||||
|     public function orWhere($where) | ||||
|     { | ||||
|         $args = func_get_args(); | ||||
|         $args  = func_get_args(); | ||||
|         $where = $this->getQueryPart('where'); | ||||
|  | ||||
|         if ($where instanceof CompositeExpression && $where->getType() === CompositeExpression::TYPE_OR) { | ||||
| @@ -955,7 +934,7 @@ class QueryBuilder | ||||
|      *         ); | ||||
|      * </code> | ||||
|      * | ||||
|      * @param array $values The values to specify for the insert query indexed by column names. | ||||
|      * @param mixed[] $values The values to specify for the insert query indexed by column names. | ||||
|      * | ||||
|      * @return $this This QueryBuilder instance. | ||||
|      */ | ||||
| @@ -974,7 +953,7 @@ class QueryBuilder | ||||
|      */ | ||||
|     public function having($having) | ||||
|     { | ||||
|         if ( ! (func_num_args() == 1 && $having instanceof CompositeExpression)) { | ||||
|         if (! (func_num_args() === 1 && $having instanceof CompositeExpression)) { | ||||
|             $having = new CompositeExpression(CompositeExpression::TYPE_AND, func_get_args()); | ||||
|         } | ||||
|  | ||||
| @@ -991,7 +970,7 @@ class QueryBuilder | ||||
|      */ | ||||
|     public function andHaving($having) | ||||
|     { | ||||
|         $args = func_get_args(); | ||||
|         $args   = func_get_args(); | ||||
|         $having = $this->getQueryPart('having'); | ||||
|  | ||||
|         if ($having instanceof CompositeExpression && $having->getType() === CompositeExpression::TYPE_AND) { | ||||
| @@ -1014,7 +993,7 @@ class QueryBuilder | ||||
|      */ | ||||
|     public function orHaving($having) | ||||
|     { | ||||
|         $args = func_get_args(); | ||||
|         $args   = func_get_args(); | ||||
|         $having = $this->getQueryPart('having'); | ||||
|  | ||||
|         if ($having instanceof CompositeExpression && $having->getType() === CompositeExpression::TYPE_OR) { | ||||
| @@ -1069,7 +1048,7 @@ class QueryBuilder | ||||
|     /** | ||||
|      * Gets all query parts. | ||||
|      * | ||||
|      * @return array | ||||
|      * @return mixed[] | ||||
|      */ | ||||
|     public function getQueryParts() | ||||
|     { | ||||
| @@ -1079,7 +1058,7 @@ class QueryBuilder | ||||
|     /** | ||||
|      * Resets SQL parts. | ||||
|      * | ||||
|      * @param array|null $queryPartNames | ||||
|      * @param string[]|null $queryPartNames | ||||
|      * | ||||
|      * @return $this This QueryBuilder instance. | ||||
|      */ | ||||
| @@ -1116,7 +1095,7 @@ class QueryBuilder | ||||
|     /** | ||||
|      * @return string | ||||
|      * | ||||
|      * @throws \Doctrine\DBAL\Query\QueryException | ||||
|      * @throws QueryException | ||||
|      */ | ||||
|     private function getSQLForSelect() | ||||
|     { | ||||
| @@ -1144,16 +1123,16 @@ class QueryBuilder | ||||
|      */ | ||||
|     private function getFromClauses() | ||||
|     { | ||||
|         $fromClauses = []; | ||||
|         $fromClauses  = []; | ||||
|         $knownAliases = []; | ||||
|  | ||||
|         // Loop through all FROM clauses | ||||
|         foreach ($this->sqlParts['from'] as $from) { | ||||
|             if ($from['alias'] === null) { | ||||
|                 $tableSql = $from['table']; | ||||
|                 $tableSql       = $from['table']; | ||||
|                 $tableReference = $from['table']; | ||||
|             } else { | ||||
|                 $tableSql = $from['table'] . ' ' . $from['alias']; | ||||
|                 $tableSql       = $from['table'] . ' ' . $from['alias']; | ||||
|                 $tableReference = $from['alias']; | ||||
|             } | ||||
|  | ||||
| @@ -1168,14 +1147,14 @@ class QueryBuilder | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param array $knownAliases | ||||
|      * @param string[] $knownAliases | ||||
|      * | ||||
|      * @throws QueryException | ||||
|      */ | ||||
|     private function verifyAllAliasesAreKnown(array $knownAliases) | ||||
|     { | ||||
|         foreach ($this->sqlParts['join'] as $fromAlias => $joins) { | ||||
|             if ( ! isset($knownAliases[$fromAlias])) { | ||||
|             if (! isset($knownAliases[$fromAlias])) { | ||||
|                 throw QueryException::unknownAlias($fromAlias, array_keys($knownAliases)); | ||||
|             } | ||||
|         } | ||||
| @@ -1209,11 +1188,9 @@ class QueryBuilder | ||||
|     private function getSQLForUpdate() | ||||
|     { | ||||
|         $table = $this->sqlParts['from']['table'] . ($this->sqlParts['from']['alias'] ? ' ' . $this->sqlParts['from']['alias'] : ''); | ||||
|         $query = 'UPDATE ' . $table | ||||
|             . ' SET ' . implode(", ", $this->sqlParts['set']) | ||||
|         return 'UPDATE ' . $table | ||||
|             . ' SET ' . implode(', ', $this->sqlParts['set']) | ||||
|             . ($this->sqlParts['where'] !== null ? ' WHERE ' . ((string) $this->sqlParts['where']) : ''); | ||||
|  | ||||
|         return $query; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -1224,9 +1201,7 @@ class QueryBuilder | ||||
|     private function getSQLForDelete() | ||||
|     { | ||||
|         $table = $this->sqlParts['from']['table'] . ($this->sqlParts['from']['alias'] ? ' ' . $this->sqlParts['from']['alias'] : ''); | ||||
|         $query = 'DELETE FROM ' . $table . ($this->sqlParts['where'] !== null ? ' WHERE ' . ((string) $this->sqlParts['where']) : ''); | ||||
|  | ||||
|         return $query; | ||||
|         return 'DELETE FROM ' . $table . ($this->sqlParts['where'] !== null ? ' WHERE ' . ((string) $this->sqlParts['where']) : ''); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -1260,7 +1235,6 @@ class QueryBuilder | ||||
|      * $stmt = $q->executeQuery(); // executed with 'id = 2' | ||||
|      * </code> | ||||
|      * | ||||
|      * @license New BSD License | ||||
|      * @link http://www.zetacomponents.org | ||||
|      * | ||||
|      * @param mixed  $value | ||||
| @@ -1273,7 +1247,7 @@ class QueryBuilder | ||||
|     { | ||||
|         if ($placeHolder === null) { | ||||
|             $this->boundCounter++; | ||||
|             $placeHolder = ":dcValue" . $this->boundCounter; | ||||
|             $placeHolder = ':dcValue' . $this->boundCounter; | ||||
|         } | ||||
|         $this->setParameter(substr($placeHolder, 1), $value, $type); | ||||
|  | ||||
| @@ -1307,12 +1281,12 @@ class QueryBuilder | ||||
|         $this->boundCounter++; | ||||
|         $this->setParameter($this->boundCounter, $value, $type); | ||||
|  | ||||
|         return "?"; | ||||
|         return '?'; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $fromAlias | ||||
|      * @param array  $knownAliases | ||||
|      * @param string   $fromAlias | ||||
|      * @param string[] $knownAliases | ||||
|      * | ||||
|      * @return string | ||||
|      * | ||||
| @@ -1327,7 +1301,7 @@ class QueryBuilder | ||||
|                 if (array_key_exists($join['joinAlias'], $knownAliases)) { | ||||
|                     throw QueryException::nonUniqueAlias($join['joinAlias'], array_keys($knownAliases)); | ||||
|                 } | ||||
|                 $sql .= ' ' . strtoupper($join['joinType']) | ||||
|                 $sql                             .= ' ' . strtoupper($join['joinType']) | ||||
|                     . ' JOIN ' . $join['joinTable'] . ' ' . $join['joinAlias'] | ||||
|                     . ' ON ' . ((string) $join['joinCondition']); | ||||
|                 $knownAliases[$join['joinAlias']] = true; | ||||
| @@ -1351,9 +1325,11 @@ class QueryBuilder | ||||
|         foreach ($this->sqlParts as $part => $elements) { | ||||
|             if (is_array($this->sqlParts[$part])) { | ||||
|                 foreach ($this->sqlParts[$part] as $idx => $element) { | ||||
|                     if (is_object($element)) { | ||||
|                         $this->sqlParts[$part][$idx] = clone $element; | ||||
|                     if (! is_object($element)) { | ||||
|                         continue; | ||||
|                     } | ||||
|  | ||||
|                     $this->sqlParts[$part][$idx] = clone $element; | ||||
|                 } | ||||
|             } elseif (is_object($elements)) { | ||||
|                 $this->sqlParts[$part] = clone $elements; | ||||
| @@ -1361,9 +1337,11 @@ class QueryBuilder | ||||
|         } | ||||
|  | ||||
|         foreach ($this->params as $name => $param) { | ||||
|             if (is_object($param)) { | ||||
|                 $this->params[$name] = clone $param; | ||||
|             if (! is_object($param)) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             $this->params[$name] = clone $param; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,55 +1,35 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Query; | ||||
|  | ||||
| use Doctrine\DBAL\DBALException; | ||||
| use function implode; | ||||
|  | ||||
| /** | ||||
|  * @since 2.1.4 | ||||
|  */ | ||||
| class QueryException extends DBALException | ||||
| { | ||||
|     /** | ||||
|      * @param string $alias | ||||
|      * @param array  $registeredAliases | ||||
|      * @param string   $alias | ||||
|      * @param string[] $registeredAliases | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Query\QueryException | ||||
|      */ | ||||
|     public static function unknownAlias($alias, $registeredAliases) | ||||
|     { | ||||
|         return new self("The given alias '" . $alias . "' is not part of " . | ||||
|             "any FROM or JOIN clause table. The currently registered " . | ||||
|             "aliases are: " . implode(", ", $registeredAliases) . "."); | ||||
|             'any FROM or JOIN clause table. The currently registered ' . | ||||
|             'aliases are: ' . implode(', ', $registeredAliases) . '.'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $alias | ||||
|      * @param array  $registeredAliases | ||||
|      * @param string   $alias | ||||
|      * @param string[] $registeredAliases | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Query\QueryException | ||||
|      */ | ||||
|     public static function nonUniqueAlias($alias, $registeredAliases) | ||||
|     { | ||||
|         return new self("The given alias '" . $alias . "' is not unique " . | ||||
|             "in FROM and JOIN clause table. The currently registered " . | ||||
|             "aliases are: " . implode(", ", $registeredAliases) . "."); | ||||
|             'in FROM and JOIN clause table. The currently registered ' . | ||||
|             'aliases are: ' . implode(', ', $registeredAliases) . '.'); | ||||
|     } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Manish Verma
					Manish Verma