Я знаю, что это для случая типа pdo mysql ... но я делаю методы сборки pdo-оболочки, и в этом случае я делаю эту функцию, которая помогает создавать строку, так как мы работаем с ключами, естьневозможно ввести MySQL, поскольку я знаю ключи, которые я определяю / принимаю вручную.
представьте себе эти данные:
$data=array(
"name"=>$_GET["name"],
"email"=>$_GET["email"]
);
вы определили методы utils ...
public static function serialize_type($obj,$mode){
$d2="";
if($mode=="insert"){
$d2.=" (".implode(",",array_keys($obj)).") ";
$d2.=" VALUES(";
foreach ($obj as $key=>$item){$d2.=":".$key.",";}
$d2=rtrim($d2,",").")";}
if($mode=="update"){
foreach ($obj as $key=>$item){$d2.=$key."=:".$key.",";}
}
return rtrim($d2,",");
}
затем построитель массива привязки запроса (я мог бы использовать прямую ссылку на массив, но позволяетупростить):
public static function bind_build($array){
$query_array=$array;
foreach ($query_array as $key => $value) { $query_array[":".$key] = $query_array[$key]; unset($query_array[$key]); } //auto prepair array for PDO
return $query_array; }
затем вы выполните ...
$query ="insert into table_x ".self::serialize_type( $data, "insert" );
$me->statement = @$me->dbh->prepare( $query );
$me->result=$me->statement->execute( self::bind_build($data) );
Вы также можете легко перейти на обновление с ...
$query ="update table_x set ".self::serialize_type( $data, "update" )." where id=:id";
$me->statement = @$me->dbh->prepare( $query );
$data["id"]="123"; //add the id
$me->result=$me->statement->execute( self::bind_build($data) );
Но самой важной частью здесь является функция serialize_type