-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
/
Copy pathQueryParts.php
74 lines (56 loc) · 1.41 KB
/
QueryParts.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
63
64
65
66
67
68
69
70
71
72
73
74
<?php
declare(strict_types=1);
namespace Doctrine\DBAL\Query;
use Doctrine\DBAL\Query\Expression\CompositeExpression;
/**
* @internal
*/
class QueryParts
{
/** @var string[] */
public $select = [];
/** @var bool */
public $distinct = false;
/** @var From[] */
public $from = [];
/** @var string|null */
public $table;
/**
* Lists of joins indexed by from alias.
*
* @var array<string, Join[]>
*/
public $join = [];
/** @var string[] */
public $set = [];
/** @var CompositeExpression|null */
public $where = null;
/** @var string[] */
public $groupBy = [];
/** @var CompositeExpression|null */
public $having = null;
/** @var string[] */
public $orderBy = [];
/** @var array<string, mixed> */
public $values = [];
/**
* Deep clone of all expression objects in the SQL parts.
*/
public function __clone()
{
foreach ($this->from as $key => $from) {
$this->from[$key] = clone $from;
}
foreach ($this->join as $fromAlias => $joins) {
foreach ($joins as $key => $join) {
$this->join[$fromAlias][$key] = clone $join;
}
}
if ($this->where !== null) {
$this->where = clone $this->where;
}
if ($this->having !== null) {
$this->having = clone $this->having;
}
}
}