- Began decoupling of QueryBuilder from native MySQL method ; some works needs to be done on for the Repository object splitting also.
51 lines
1.1 KiB
PHP
51 lines
1.1 KiB
PHP
<?php
|
|
|
|
namespace Ulmus\Query;
|
|
|
|
use Ulmus\MysqlQueryBuilder;
|
|
|
|
class Set extends Fragment {
|
|
|
|
public int $order = 0;
|
|
|
|
public array $dataset;
|
|
|
|
public ? array $escapedFields;
|
|
|
|
public QueryBuilderInterface $queryBuilder;
|
|
|
|
public function __construct(QueryBuilderInterface $queryBuilder)
|
|
{
|
|
$this->queryBuilder = $queryBuilder;
|
|
}
|
|
|
|
public function set(array $dataset, ? array $escapedFields = null) : self
|
|
{
|
|
$this->dataset = $dataset;
|
|
$this->escapedFields = $escapedFields;
|
|
|
|
return $this;
|
|
}
|
|
|
|
public function render() /* : mixed */
|
|
{
|
|
return $this->renderSegments([
|
|
'SET', $this->renderParameterPlaceholders(),
|
|
]);
|
|
}
|
|
|
|
public function renderParameterPlaceholders() : string
|
|
{
|
|
$keys = [];
|
|
|
|
foreach($this->dataset as $key =>$value) {
|
|
$this->queryBuilder->addParameter($value, ":v_$key");
|
|
|
|
$field = $this->escapedFields[$key] ?? $key;
|
|
|
|
$keys[] = "{$field}=:v_{$key}";
|
|
}
|
|
|
|
return implode(",", $keys);
|
|
}
|
|
} |