PHP PDO ОБНОВИТЬ переменные поля, используя IF - PullRequest
0 голосов
/ 15 мая 2018

У меня есть функция для обновления до 3 полей в таблице MySQL. Функция может получать все 3 поля для обновления или только 1 или 2

Прямо сейчас я делаю это так (это работает) для создания оператора MySQL.

if ($foo1){
   $mysql_set = '`foo1` = :foo1';}
if ($foo2){
   if ($mysql_set){$mysql_set .= ', ';}
   $mysql_set .= '`foo2` = :foo2';}
if ($foo3){
   if ($mysql_set){$mysql_set .= ', ';}
   $mysql_set .= '`foo3` = :foo3';}

$update = $db->prepare("UPDATE `bar` SET $mysql_set WHERE `id` = :id");

if ($foo1){
   $update->bindValue(':foo1', $foo1, PDO::PARAM_STR);}
if ($foo2){
   $update->bindValue(':foo2', $foo2, PDO::PARAM_STR);}
if ($foo3){
   $update->bindValue(':foo3', $foo3, PDO::PARAM_STR);}
$update->bindValue(':id', $id, PDO::PARAM_INT);
$update->execute();

Как видите, я повторяю "if ($ foo1 - $ foo3) {}" дважды, чтобы построить этот запрос MySQL. Это выглядит избыточно и интересно, есть ли лучший способ справиться с этим сценарием.

Ответы [ 2 ]

0 голосов
/ 15 мая 2018

Попробуйте.

   if ($foo1){
       $mysql_set = '`foo1` = :foo1';
       $update = prepareStmt($db, $mysql_set);
       $update->bindValue(':foo1', $foo1, PDO::PARAM_STR);
    }
    if ($foo2){
       if ($mysql_set){$mysql_set .= ', ';}
       $mysql_set .= '`foo2` = :foo2';
    $update = prepareStmt($db, $mysql_set);
    $update->bindValue(':foo2', $foo2, PDO::PARAM_STR);
    }
    if ($foo3){
       if ($mysql_set){$mysql_set .= ', ';}
       $mysql_set .= '`foo3` = :foo3';
    $update = prepareStmt($db, $mysql_set);
    $update->bindValue(':foo3', $foo3, PDO::PARAM_STR);
    }


    $update->bindValue(':id', $id, PDO::PARAM_INT);
    $update->execute();

    function prepareStmt($db,$mysql_set){
        return $db->prepare("UPDATE `bar` SET $mysql_set WHERE `id` = :id");
    }
0 голосов
/ 15 мая 2018

Вы можете присвоить ассоциативный массив execute() вместо вызова bindValue() отдельно для каждого параметра.

$param_array = array(':id' => $id);
$set_array = array();
if ($foo1) {
    $param_array[':foo1'] = $foo1;
    $set_array[] = "foo1 = :foo1";
}
if ($foo2) {
    $param_array[':foo2'] = $foo2;
    $set_array[] = "foo2 = :foo2";
}
if ($foo3) {
    $param_array[':foo3'] = $foo3;
    $set_array[] = "foo3 = :foo3";
}
if (!empty($set_array)) {
    $set_string = implode(", ", $set_array);
    $sql = "UPDATE bar SET $set_string WHERE id = :id";
    $update = $db->prepare($sql);
    $update->execute($param_array);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...