Php PDO错误:";无效参数编号:未定义参数";

Php PDO错误:";无效参数编号:未定义参数";,php,mysql,pdo,prepared-statement,parameterized-query,Php,Mysql,Pdo,Prepared Statement,Parameterized Query,我正在尝试使用一个简单的MySQL insert查询,其中包含数组形式的参数。它不断告诉我参数的数量是错误的。我尝试了以下操作,但都产生了相同的错误: $stmt3 = $link->prepare('INSERT INTO messages VALUES(null, :room, :name, :message, :time, :color)'); $stmt3->execute(array(':room' => $Clean['room'],':name' => $C

我正在尝试使用一个简单的MySQL insert查询,其中包含数组形式的参数。它不断告诉我参数的数量是错误的。我尝试了以下操作,但都产生了相同的错误:

$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 (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(),因此从这个角度出发的任何见解都是值得赞赏的。

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

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

问题在于
:color

调用
execute()
时为该标记传递的值的数组键名为
:color:
。请删除尾随的
(我猜这只是一个打字错误)


根据我正在使用的数组方法,这是一种可选的方法。你的第二个例子是我如何使用mysqli,但我真的很想这样做是为了可读性,我对这个错误投入了太多,我真的很想知道是什么导致了它。天哪,我现在恨我自己。我不敢相信我盯着这个看一个半小时没看到……我花了几分钟。有时候你只需要新鲜的眼睛,这就是我们在这里的目的;-)嘿嘿+1新鲜的眼睛!接得好Dave@Dave你完全正确。我太专注于它了,以至于抓不到那么小的东西。谢谢!只要我的5美分。我对这个一般性错误也有同样的问题。在命名约定中将近1小时后找到了解决方案。参数名称中不能有连字符(-)。删除连字符后,一切正常!
$stmt3 = $link->prepare('INSERT INTO messages VALUES(null, ?, ?, ?, ?, ?)');
$stmt3->execute(array($Clean['room'], $Clean['name'], $Clean['message'], $time, $Clean['color']))
$stmt3->execute(array(
    ':room' => $Clean['room'],
    ':name' => $Clean['name'],
    ':message' => $Clean['message'],
    ':time' => $time,
    ':color' => $Clean['color'],
    ));