Ошибка PDO: «Недопустимый номер параметра: параметр не определен»

Я пытаюсь использовать простой запрос вставки MySQL с параметрами в форме массива. Он продолжает говорить мне, что количество параметров неверно. Я пробовал следующее, все производя ту же ошибку:

$stmt3 = $link->prepare('INSERT INTO messages VALUES(null, :room, :name, :message, :time, :color)'); $stmt3->execute(array(':room' => $Clean['room'],':name' => $Clean['name'],':message' => $Clean['message'],':time' => $time,':color:' => $Clean['color'])); 

а также

 $stmt3 = $link->prepare('INSERT INTO messages VALUES(:null, :room, :name, :message, :time, :color)'); $stmt3->execute(array(':null' => null, ':room' => $Clean['room'],':name' => $Clean['name'],':message' => $Clean['message'],':time' => $time,':color:' => $Clean['color'])); 

а также объявление столбцов специально для исключения нулевой вставки:

 $stmt3 = $link->prepare('INSERT INTO messages (room, name, message, time, color) VALUES(:room, :name, :message, :time, :color)'); $stmt3->execute(array(':room' => $Clean['room'],':name' => $Clean['name'],':message' => $Clean['message'],':time' => $time,':color:' => $Clean['color'])); 

Это мой первый раз, когда я использую PDO (я обычно использую mysqli, но мой текущий общий хост не имеет плагина mysqlnd, что мешает мне использовать prepare (), поэтому любое понимание с этой точки зрения оценено.

Проблема – и вы будете пинать себя – это :color .

Ключ массива для значения, которое вы передаете для этого маркера при вызове execute() , называется :color: Удалите трейлинг : (я предполагаю, что это была просто опечатка).

 $stmt3->execute(array( ':room' => $Clean['room'], ':name' => $Clean['name'], ':message' => $Clean['message'], ':time' => $time, ':color' => $Clean['color'], )); 

Возможно, я ошибаюсь, но, насколько я знаю, вам нужно сделать это:

 $stmt3->bindParam(':room', $Clean['room']); $stmt3->bindParam(':name', $Clean['name']); //and so on 

Но, как личное предпочтение, я всегда делал это так

 $stmt3 = $link->prepare('INSERT INTO messages VALUES(null, ?, ?, ?, ?, ?)'); $stmt3->execute(array($Clean['room'], $Clean['name'], $Clean['message'], $time, $Clean['color']))