Test Failed
Pull Request — master (#210)
by Wilmer
07:09 queued 03:19
created

InConditionBuilder::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 0
Metric Value
eloc 1
dl 0
loc 3
ccs 2
cts 2
cp 1
rs 10
c 0
b 0
f 0
cc 1
nc 1
nop 1
crap 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Db\Sqlite\Builder;
6
7
use Iterator;
8
use Yiisoft\Db\Exception\Exception;
9
use Yiisoft\Db\Exception\InvalidArgumentException;
10
use Yiisoft\Db\Exception\InvalidConfigException;
11
use Yiisoft\Db\Exception\NotSupportedException;
12
use Yiisoft\Db\Expression\ExpressionInterface;
13
use Yiisoft\Db\QueryBuilder\Condition\Builder\InConditionBuilder as BaseInConditionBuilder;
14
15
use function implode;
16
use function is_array;
17
use function str_contains;
18
19
/**
20
 * InConditionBuilder builds conditions for {@see `\Yiisoft\Db\QueryBuilder\Condition\InCondition`} IN operator for
21
 * SQLite.
22
 */
23 39
final class InConditionBuilder extends BaseInConditionBuilder
24
{
25 39
    /**
26
     * Builds SQL for IN condition.
27
     *
28
     * @throws Exception|InvalidArgumentException|InvalidConfigException|NotSupportedException
29
     *
30
     * @return string SQL.
31
     */
32
    protected function buildSubqueryInCondition(
33
        string $operator,
34
        iterable|string|Iterator $columns,
35 3
        ExpressionInterface $values,
36
        array &$params = []
37
    ): string {
38
        if (is_array($columns)) {
39
            throw new NotSupportedException(__METHOD__ . ' is not supported by SQLite.');
40
        }
41 3
42 1
        return parent::buildSubqueryInCondition($operator, $columns, $values, $params);
43
    }
44
45 2
    /**
46
     * Builds SQL for IN condition.
47
     *
48
     * @throws Exception
49
     * @throws InvalidArgumentException
50
     * @throws InvalidConfigException
51
     * @throws NotSupportedException
52
     */
53 9
    protected function buildCompositeInCondition(
54
        string|null $operator,
55
        iterable $columns,
56
        iterable|Iterator $values,
57
        array &$params = []
58
    ): string {
59 9
        $quotedColumns = [];
60
61
        /** @psalm-var string[] $columns */
62 9
        foreach ($columns as $i => $column) {
63 9
            if ($column instanceof ExpressionInterface) {
64 1
                $quotedColumns[$i] = $this->queryBuilder->buildExpression($column);
0 ignored issues
show
Bug introduced by
The property queryBuilder is declared private in Yiisoft\Db\QueryBuilder\...lder\InConditionBuilder and cannot be accessed from this context.
Loading history...
65 1
                continue;
66
            }
67 8
            $quotedColumns[$i] = !str_contains($column, '(')
68 8
                ? $this->queryBuilder->quoter()->quoteColumnName($column) : $column;
69
        }
70
71 9
        $vss = [];
72
73
        /** @psalm-var string[][] $values */
74 9
        foreach ($values as $value) {
75 9
            $vs = [];
76 9
            foreach ($columns as $i => $column) {
77 9
                if ($column instanceof ExpressionInterface) {
78 1
                    $column = $this->queryBuilder->buildExpression($column);
79
                }
80 9
                if (isset($value[$column])) {
81 9
                    $phName = $this->queryBuilder->bindParam($value[$column], $params);
82 9
                    $vs[] = $quotedColumns[$i] . ($operator === 'IN' ? ' = ' : ' != ') . $phName;
83
                } else {
84 3
                    $vs[] = $quotedColumns[$i] . ($operator === 'IN' ? ' IS' : ' IS NOT') . ' NULL';
85
                }
86
            }
87 9
            $vss[] = '(' . implode($operator === 'IN' ? ' AND ' : ' OR ', $vs) . ')';
88
        }
89
90 9
        return '(' . implode($operator === 'IN' ? ' OR ' : ' AND ', $vss) . ')';
91
    }
92
}
93