Passed
Pull Request — master (#14)
by Wilmer
15:58 queued 01:00
created

InConditionBuilder   A

Complexity

Total Complexity 12

Size/Duplication

Total Lines 32
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 18
dl 0
loc 32
rs 10
c 0
b 0
f 0
wmc 12

2 Methods

Rating   Name   Duplication   Size   Complexity  
A buildSubqueryInCondition() 0 7 2
B buildCompositeInCondition() 0 21 10
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Db\Mssql\Condition;
6
7
use Yiisoft\Db\Exception\NotSupportedException;
8
9
final class InConditionBuilder extends Yiisoft\Db\Query\Conditions\InConditionBuilder
0 ignored issues
show
Bug introduced by
The type Yiisoft\Db\Mssql\Conditi...ions\InConditionBuilder was not found. Did you mean Yiisoft\Db\Query\Conditions\InConditionBuilder? If so, make sure to prefix the type with \.
Loading history...
10
{
11
    protected function buildSubqueryInCondition($operator, $columns, $values, &$params)
12
    {
13
        if (is_array($columns)) {
14
            throw new NotSupportedException(__METHOD__ . ' is not supported by MSSQL.');
15
        }
16
17
        return parent::buildSubqueryInCondition($operator, $columns, $values, $params);
18
    }
19
20
    protected function buildCompositeInCondition($operator, $columns, $values, &$params)
21
    {
22
        $quotedColumns = [];
23
        foreach ($columns as $i => $column) {
24
            $quotedColumns[$i] = strpos($column, '(') === false ? $this->queryBuilder->db->quoteColumnName($column) : $column;
25
        }
26
        $vss = [];
27
        foreach ($values as $value) {
28
            $vs = [];
29
            foreach ($columns as $i => $column) {
30
                if (isset($value[$column])) {
31
                    $phName = $this->queryBuilder->bindParam($value[$column], $params);
32
                    $vs[] = $quotedColumns[$i] . ($operator === 'IN' ? ' = ' : ' != ') . $phName;
33
                } else {
34
                    $vs[] = $quotedColumns[$i] . ($operator === 'IN' ? ' IS' : ' IS NOT') . ' NULL';
35
                }
36
            }
37
            $vss[] = '(' . implode($operator === 'IN' ? ' AND ' : ' OR ', $vs) . ')';
38
        }
39
40
        return '(' . implode($operator === 'IN' ? ' OR ' : ' AND ', $vss) . ')';
41
    }
42
}
43