114 lines
2.4 KiB
PHP
114 lines
2.4 KiB
PHP
|
<?php
|
||
|
|
||
|
/*
|
||
|
* This file is part of the Symfony package.
|
||
|
*
|
||
|
* (c) Fabien Potencier <fabien@symfony.com>
|
||
|
*
|
||
|
* For the full copyright and license information, please view the LICENSE
|
||
|
* file that was distributed with this source code.
|
||
|
*/
|
||
|
|
||
|
namespace Symfony\Bridge\Doctrine\Middleware\Debug;
|
||
|
|
||
|
use Doctrine\DBAL\ParameterType;
|
||
|
|
||
|
/**
|
||
|
* @author Laurent VOULLEMIER <laurent.voullemier@gmail.com>
|
||
|
*
|
||
|
* @internal
|
||
|
*/
|
||
|
class Query
|
||
|
{
|
||
|
private array $params = [];
|
||
|
|
||
|
/** @var array<ParameterType|int> */
|
||
|
private array $types = [];
|
||
|
|
||
|
private ?float $start = null;
|
||
|
private ?float $duration = null;
|
||
|
|
||
|
public function __construct(
|
||
|
private readonly string $sql,
|
||
|
) {
|
||
|
}
|
||
|
|
||
|
public function start(): void
|
||
|
{
|
||
|
$this->start = microtime(true);
|
||
|
}
|
||
|
|
||
|
public function stop(): void
|
||
|
{
|
||
|
if (null !== $this->start) {
|
||
|
$this->duration = microtime(true) - $this->start;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function setParam(string|int $param, mixed &$variable, ParameterType|int $type): void
|
||
|
{
|
||
|
// Numeric indexes start at 0 in profiler
|
||
|
$idx = \is_int($param) ? $param - 1 : $param;
|
||
|
|
||
|
$this->params[$idx] = &$variable;
|
||
|
$this->types[$idx] = $type;
|
||
|
}
|
||
|
|
||
|
public function setValue(string|int $param, mixed $value, ParameterType|int $type): void
|
||
|
{
|
||
|
// Numeric indexes start at 0 in profiler
|
||
|
$idx = \is_int($param) ? $param - 1 : $param;
|
||
|
|
||
|
$this->params[$idx] = $value;
|
||
|
$this->types[$idx] = $type;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param array<string|int, string|int|float> $values
|
||
|
*/
|
||
|
public function setValues(array $values): void
|
||
|
{
|
||
|
foreach ($values as $param => $value) {
|
||
|
$this->setValue($param, $value, ParameterType::STRING);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function getSql(): string
|
||
|
{
|
||
|
return $this->sql;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return array<int, string|int|float}>
|
||
|
*/
|
||
|
public function getParams(): array
|
||
|
{
|
||
|
return $this->params;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return array<int, int|ParameterType>
|
||
|
*/
|
||
|
public function getTypes(): array
|
||
|
{
|
||
|
return $this->types;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Query duration in seconds.
|
||
|
*/
|
||
|
public function getDuration(): ?float
|
||
|
{
|
||
|
return $this->duration;
|
||
|
}
|
||
|
|
||
|
public function __clone()
|
||
|
{
|
||
|
$copy = [];
|
||
|
foreach ($this->params as $param => $valueOrVariable) {
|
||
|
$copy[$param] = $valueOrVariable;
|
||
|
}
|
||
|
$this->params = $copy;
|
||
|
}
|
||
|
}
|