carno-php /
database
| 1 | <?php |
||
| 2 | /** |
||
| 3 | * Params binding |
||
| 4 | * User: moyo |
||
| 5 | * Date: 15/12/2017 |
||
| 6 | * Time: 3:59 PM |
||
| 7 | */ |
||
| 8 | |||
| 9 | namespace Carno\Database\Chips; |
||
| 10 | |||
| 11 | trait ParamsBind |
||
| 12 | { |
||
| 13 | /** |
||
| 14 | * @var string |
||
| 15 | */ |
||
| 16 | private $pbks = '{![%s]-}'; |
||
| 17 | |||
| 18 | /** |
||
| 19 | * @param string $sql |
||
| 20 | * @param array $params |
||
| 21 | * @return string |
||
| 22 | */ |
||
| 23 | protected function binding(string $sql, array $params) : string |
||
| 24 | { |
||
| 25 | // sort by key length (make correct of ":test,:test2") |
||
| 26 | uksort($params, static function ($a, $b) { |
||
| 27 | return strlen($b) - strlen($a); |
||
| 28 | }); |
||
| 29 | |||
| 30 | // prepare slots |
||
| 31 | foreach ($params as $name => $data) { |
||
| 32 | is_scalar($data) && $sql = str_ireplace([":{$name}", "?{$name}"], sprintf($this->pbks, $name), $sql); |
||
| 33 | } |
||
| 34 | |||
| 35 | // data replaced |
||
| 36 | foreach ($params as $name => $data) { |
||
| 37 | is_scalar($data) && $sql = str_ireplace(sprintf($this->pbks, $name), '"'.$this->escape($data).'"', $sql); |
||
|
0 ignored issues
–
show
Bug
introduced
by
Loading history...
|
|||
| 38 | } |
||
| 39 | |||
| 40 | return $sql; |
||
| 41 | } |
||
| 42 | } |
||
| 43 |