Passed
Push — main ( a619f1...d1dc3f )
by Osvaldo
05:24
created

Joins::sql()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 10
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 5
CRAP Score 2

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 2
eloc 4
c 1
b 0
f 0
nc 2
nop 0
dl 0
loc 10
ccs 5
cts 5
cp 1
crap 2
rs 10
1
<?php
2
namespace src\pdodatabase\elementos;
3
4
use src\pdodatabase\elementos\Tabla;
5
use src\pdodatabase\elementos\Campos;
6
7
class Joins
8
{
9
    private $_joins;
10
    private $_tabla;
11
    private $_campos;
12
13 1
    public function __construct(Tabla $Tabla, Campos $Campos, array $Joins)
14
    {
15 1
        $this->_joins = array_reverse( (array) $Joins);
16 1
        $this->_tabla = $Tabla;
17 1
        $this->_campos = $this->setCampos($Campos->sql());
18
        
19 1
    }
20
21 1
    public function sql(): string
22
    {
23 1
        $sql = '';
24
25 1
        foreach ($this->_joins as $join)
26
        {
27 1
            $sql = $join->sql().' '.$sql;
28
        }
29
30 1
        return 'SELECT '.$this->_campos.','.$this->campos(). ' FROM '. $this->_tabla->sql().' '.$sql;
31
    }
32
33 1
    private function campos(): string
34
    {
35 1
        $campos = '';
36
37 1
        foreach ($this->_joins as $join)
38
        {
39 1
            $campos = $campos.$join->campos().',';
40
        }
41
42 1
        return trim($campos,',');
43
    }
44
45 1
    private function setCampos(string $campos): string
46
    {
47 1
        $campos = str_replace(',',','.$this->_tabla->sql().'.',$campos);
48
49 1
        return $this->_tabla->sql().'.'.$campos;
50
    }
51
}