php – 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,:color)');
$stmt3->execute(array(':null' => null,':room' => $Clean['room'],':color:' => $Clean['color']));

以及专门声明列以避免空插入:

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

这是我第一次使用PDO(我通常使用MysqLi,但我当前的共享主机没有MysqLnd插件,阻止我使用prepare(),所以从这个角度来看任何洞察都是值得赞赏的.

最佳答案
问题 – 你会踢自己 – 是:颜色.

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

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

相关文章

优化MySQL数据库发布系统存储的方法有:1.mysql库主从读写分...
使用mysql的方法:在“我的电脑”→右键→“管理”→“服务”...
在mysql中查看root用户权限的方法:1.命令行启动mysql服务;...
MySQL主从复制是用来备份一个与主数据库一样环境的从数据库,...
运行mysql的方法1.启动mysql服务,在“我的电脑”→右键→“...
开启mysql的方法1.可以通过快捷键win+r,输入cmd,打开窗口,...