Passed
Push — master ( 52cf02...273cba )
by Alexander
18:21 queued 14:33
created

InConditionBuilder   A

Complexity

Total Complexity 12

Size/Duplication

Total Lines 39
Duplicated Lines 0 %

Test Coverage

Coverage 62.96%

Importance

Changes 0
Metric Value
eloc 18
dl 0
loc 39
ccs 17
cts 27
cp 0.6296
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
 * @link http://www.yiiframework.com/
4
 * @copyright Copyright (c) 2008 Yii Software LLC
5
 * @license http://www.yiiframework.com/license/
6
 */
7
8
namespace yii\db\mssql\conditions;
9
10
use yii\base\NotSupportedException;
11
12
/**
13
 * {@inheritdoc}
14
 *
15
 * @author Dmytro Naumenko <[email protected]>
16
 * @since 2.0.14
17
 */
18
class InConditionBuilder extends \yii\db\conditions\InConditionBuilder
19
{
20
    /**
21
     * {@inheritdoc}
22
     * @throws NotSupportedException if `$columns` is an array
23
     */
24 12
    protected function buildSubqueryInCondition($operator, $columns, $values, &$params)
25
    {
26 12
        if (is_array($columns)) {
27
            throw new NotSupportedException(__METHOD__ . ' is not supported by MSSQL.');
28
        }
29
30 12
        return parent::buildSubqueryInCondition($operator, $columns, $values, $params);
31
    }
32
33
    /**
34
     * {@inheritdoc}
35
     */
36 14
    protected function buildCompositeInCondition($operator, $columns, $values, &$params)
37
    {
38 14
        $quotedColumns = [];
39 14
        foreach ($columns as $i => $column) {
40 14
            $quotedColumns[$i] = strpos($column, '(') === false ? $this->queryBuilder->db->quoteColumnName($column) : $column;
41
        }
42 14
        $vss = [];
43 14
        foreach ($values as $value) {
44 14
            $vs = [];
45 14
            foreach ($columns as $i => $column) {
46 14
                if (isset($value[$column])) {
47 14
                    $phName = $this->queryBuilder->bindParam($value[$column], $params);
48 14
                    $vs[] = $quotedColumns[$i] . ($operator === 'IN' ? ' = ' : ' != ') . $phName;
49
                } else {
50 14
                    $vs[] = $quotedColumns[$i] . ($operator === 'IN' ? ' IS' : ' IS NOT') . ' NULL';
51
                }
52
            }
53 14
            $vss[] = '(' . implode($operator === 'IN' ? ' AND ' : ' OR ', $vs) . ')';
54
        }
55
56 14
        return '(' . implode($operator === 'IN' ? ' OR ' : ' AND ', $vss) . ')';
57
    }
58
}
59