Подготовленные операторы pdo выходят с недопустимым номером параметра - PullRequest
2 голосов
/ 06 августа 2020

У меня есть следующий запрос:

$sql="INSERT INTO form_6 SET 
      Project-name=:Project-name,
      Project-manager-gruppo-CDT=:Project-manager-gruppo-CDT,
      Short-description=:Short-description,
      Status=:Status,
      Dependency-with-BB-Pj=:Dependency-with-BB-Pj,
      Critical-issues=:Critical-issues"

и следующий массив данных, который нужно вставить:

Array ( 
    [:Project-name] => test 
    [:Project-manager-gruppo-CDT] => jack 
    [:Short-description] => simple project 
    [:Status] => on going 
    [:Dependency-with-BB-Pj] => yes 
    [:Critical-issues] => problems trying to insert data
)

, и это код, который я использую для выполнения запроса :

try{
    $stmt = $pdo->prepare($sql);
    $stmt->execute($values_array);
}
catch(PDOException $Exception){
    $message=$Exception->getMessage();
    $status=500;
    //ho avuto un problema e mi fermo
    die(json_encode(array('status'=>$status,'message' => $message)));
}

Я действительно не могу понять, почему это завершается следующим исключением:

Неверный номер параметра: параметр не был определен

обычно это происходит из-за опечаток между запросом и массивом или использования одного и того же заполнителя два раза. Но опечатки исключены, поскольку я создаю запрос и массив вместе с помощью foreach:

$values_array=array();
$sql = "INSERT INTO $tabella SET ";
foreach ($_POST as $key=>$value){
    $sql .= $key.'=:'.$key.',';
    $values_array[":$key"]=$value;
}
$sql=rtrim($sql,',');
echo $sql;  //this echoes the query at the beginning of the question
print_r($values_array);  //this echoes the array at the beginning of the question

Что мне не хватает?

1 Ответ

3 голосов
/ 06 августа 2020

Вы не можете использовать - в именах параметров. Когда вы пишете :Project-name, это эквивалентно :Profile - name, поэтому он ожидает параметр с именем :Profile, а затем пытается вычесть из него столбец name.

Замените - на _ в заполнитель.

Кроме того, если имя столбца содержит -, вам нужно поместить имя в обратные кавычки. См. Когда использовать одинарные кавычки, двойные кавычки и обратные кавычки в MySQL

$values_array=array();
$sql = "INSERT INTO $tabella SET ";
foreach ($_POST as $key=>$value){
    $placeholder = str_replace('-', '_', $key);
    $sql .= "`$key` = :$placeholder,";
    $values_array[":$placeholder"]=$value;
}
...