-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
/
Statement.php
62 lines (50 loc) · 1.68 KB
/
Statement.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
<?php
declare(strict_types=1);
namespace Doctrine\DBAL\Logging;
use Doctrine\DBAL\Driver\Middleware\AbstractStatementMiddleware;
use Doctrine\DBAL\Driver\Result as ResultInterface;
use Doctrine\DBAL\Driver\Statement as StatementInterface;
use Doctrine\DBAL\ParameterType;
use Psr\Log\LoggerInterface;
final class Statement extends AbstractStatementMiddleware
{
/** @var array<int,mixed>|array<string,mixed> */
private array $params = [];
/** @var array<int,ParameterType>|array<string,ParameterType> */
private array $types = [];
/**
* @internal This statement can be only instantiated by its connection.
*/
public function __construct(
StatementInterface $statement,
private readonly LoggerInterface $logger,
private readonly string $sql
) {
parent::__construct($statement);
}
public function bindParam(
int|string $param,
mixed &$variable,
ParameterType $type,
?int $length = null
): void {
$this->params[$param] = &$variable;
$this->types[$param] = $type;
parent::bindParam($param, $variable, $type, $length);
}
public function bindValue(int|string $param, mixed $value, ParameterType $type): void
{
$this->params[$param] = $value;
$this->types[$param] = $type;
parent::bindValue($param, $value, $type);
}
public function execute(): ResultInterface
{
$this->logger->debug('Executing statement: {sql} (parameters: {params}, types: {types})', [
'sql' => $this->sql,
'params' => $this->params,
'types' => $this->types,
]);
return parent::execute();
}
}