PDO错误:“无效的参数个数:没有定义的参数”(PDO Error: “ Invalid param

2019-06-25 13:00发布

我试图用与数组形式参数的简单的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插件,阻止我准备使用(),所以从这个角度看任何见解表示赞赏。

Answer 1:

这个问题-你会踢自己-是:color

调用,当你路过该标记的值的数组键execute()被命名为:color: 。 删除尾随: (我猜这只是一个错字反正)。

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


Answer 2:

我可能是错在这里,但据我所知,你需要这样做:

$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']))


文章来源: PDO Error: “ Invalid parameter number: parameter was not defined”