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

Join   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 32
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 15
c 1
b 0
f 0
dl 0
loc 32
ccs 14
cts 14
cp 1
rs 10
wmc 4

4 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 7 1
A campos() 0 3 1
A setCampos() 0 5 1
A sql() 0 3 1
1
<?php
2
namespace src\pdodatabase\elementos;
3
4
use src\pdodatabase\elementos\Tabla;
5
use src\pdodatabase\elementos\Campos;
6
use src\pdodatabase\elementos\NombreColumnaJoin;
7
use src\pdodatabase\elementos\TipoDeJoin;
8
9
class Join
10
{
11
    private $_tabla1;
12
    private $_tabla;
13
    private $_campos;
14
    private $_key;
15
    private $_tipoDeJoin;
16
17 3
    public function __construct(TipoDeJoin $tipoDeJoin, Tabla $tabla1, Tabla $tabla, Campos $Campos, NombreColumnaJoin $nombreColumnaJoin)
18
    {
19 3
        $this->_tipoDeJoin = $tipoDeJoin;
20 3
        $this->_tabla1 = $tabla1;
21 3
        $this->_tabla = $tabla;
22 3
        $this->_campos = $this->setCampos($Campos->sql());
23 3
        $this->_key = $nombreColumnaJoin;
24 3
    }
25
26 2
    public function sql(): string
27
    {
28 2
        return $this->_tipoDeJoin->sql().' '.$this->_tabla->sql().' ON '.$this->_tabla1->sql().'.'.$this->_key->tabla1().' = '.$this->_tabla->sql().'.'.$this->_key->tabla2();
29
    }
30
31 2
    public function campos(): string
32
    {
33 2
        return $this->_campos;
34
    }
35
36 3
    private function setCampos(string $campos): string
37
    {
38 3
        $campos = str_replace(',',','.$this->_tabla->sql().'.',$campos);
39
40 3
        return $this->_tabla->sql().'.'.$campos;
41
    }
42
43
}