123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- <?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\ORM;
- use function array_values;
- use function is_int;
- use function key;
- use function ksort;
- /**
- * Represents a native SQL query.
- */
- final class NativeQuery extends AbstractQuery
- {
- /** @var string */
- private $sql;
- /**
- * Sets the SQL of the query.
- *
- * @param string $sql
- *
- * @return self This query instance.
- */
- public function setSQL($sql): self
- {
- $this->sql = $sql;
- return $this;
- }
- /**
- * Gets the SQL query.
- *
- * @return mixed The built SQL query or an array of all SQL queries.
- *
- * @override
- */
- public function getSQL()
- {
- return $this->sql;
- }
- /**
- * {@inheritdoc}
- */
- protected function _doExecute()
- {
- $parameters = [];
- $types = [];
- foreach ($this->getParameters() as $parameter) {
- $name = $parameter->getName();
- $value = $this->processParameterValue($parameter->getValue());
- $type = $parameter->getValue() === $value
- ? $parameter->getType()
- : Query\ParameterTypeInferer::inferType($value);
- $parameters[$name] = $value;
- $types[$name] = $type;
- }
- if ($parameters && is_int(key($parameters))) {
- ksort($parameters);
- ksort($types);
- $parameters = array_values($parameters);
- $types = array_values($types);
- }
- return $this->_em->getConnection()->executeQuery(
- $this->sql,
- $parameters,
- $types,
- $this->_queryCacheProfile
- );
- }
- }
|