| Conditions | 7 |
| Paths | 48 |
| Total Lines | 28 |
| Code Lines | 21 |
| Lines | 0 |
| Ratio | 0 % |
| Changes | 0 | ||
| 1 | <?php |
||
| 28 | public function update(String $params, Array $values, Int $primary): bool |
||
| 29 | { |
||
| 30 | $params = explode(',', $params); |
||
| 31 | $data = []; |
||
| 32 | $countParams = count($params); |
||
| 33 | for($i = 0; $i < $countParams; $i++) { |
||
| 34 | $data[$i] = ":".$params[$i][0].$params[$i][1].$params[$i][2].", "; |
||
| 35 | } |
||
| 36 | $result = ''; |
||
| 37 | $final = array_map(null, $params, $data); |
||
| 38 | foreach($final as $key => $vals) { |
||
| 39 | foreach($vals as $chave => $val) { |
||
| 40 | $result .= str_replace(':', ' = :', $val); |
||
| 41 | } |
||
| 42 | } |
||
| 43 | $result = rtrim($result, ', '); |
||
| 44 | $sql = $this->conn->prepare("UPDATE {$this->table} SET {$result} WHERE {$this->primary} = '{$primary}'"); |
||
| 45 | for($i = 0; $i < $countParams; $i++) { |
||
| 46 | $data[$i] = ":".$params[$i][0].$params[$i][1].$params[$i][2]; |
||
| 47 | } |
||
| 48 | $countData = count($data); |
||
| 49 | for($i = 0; $i < $countData; $i++) { |
||
| 50 | $sql->bindParam($data[$i], $values[$i]); |
||
| 51 | } |
||
| 52 | if($sql->execute()) { |
||
| 53 | return true; |
||
| 54 | } else { |
||
| 55 | return false; |
||
| 56 | } |
||
| 58 | } |