Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/252.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php PDO-无效的参数编号_Php_Mysql_Pdo - Fatal编程技术网

Php PDO-无效的参数编号

Php PDO-无效的参数编号,php,mysql,pdo,Php,Mysql,Pdo,就在最近,我切换到在PHP/MySQL中使用PDO,并转换了几十个查询。它们中的大多数都有效,但是这个非常简单的方法在$sql->execute() PDOStatement::execute()PDOStatement.execute SQLSTATE[HY093]:无效参数编号:绑定变量的数量与中的令牌数量不匹配 经过研究,我发现了以下链接: 。。。因此尝试将查询更改为 $sql=$pdo->prepare("SELECT `id` FROM `user` WHERE `usernam

就在最近,我切换到在PHP/MySQL中使用PDO,并转换了几十个查询。它们中的大多数都有效,但是这个非常简单的方法在
$sql->execute()

PDOStatement::execute()PDOStatement.execute SQLSTATE[HY093]:无效参数编号:绑定变量的数量与中的令牌数量不匹配

经过研究,我发现了以下链接:

。。。因此尝试将查询更改为

$sql=$pdo->prepare("SELECT `id` FROM `user` WHERE `username` = :username LIMIT 1");
$sql->execute(array(':username',$username));
但仍然有相同的结果。有人看到什么明显的错误了吗?或者为什么当所有其他人都看到时,这个查询不起作用


提前非常感谢

这不是bug,您只为一个占位符提供了两个参数

$sql->execute(array(':username',$username));
应该是

$sql->execute(array(':username' => $username));

':username',$username
仅在bindParam()方法中有效:

请看这里:

对于execute,您需要传递正确的仅输入值数组:

$sql->execute(array(':username' => $username));
占位符:

您还可以使用以下选项:

$sql->execute(array($username));
但为此,您需要将查询更改为:

$sql=$pdo->prepare("SELECT `id` FROM `user` WHERE `username` = ? LIMIT 1");    

那个?充当palceholder并从数组中获取变量。当您在SQL语句中使用更多占位符时,函数将按顺序从数组中取出所有变量

“PDO-参数编号无效,尽管它是正确的”。不,这是不正确的。@Lion:是的,你是对的。。。已经更改了标题。。。我就像瞎子一样,谢谢你的帮助!
$sql->execute(array($username));
$sql=$pdo->prepare("SELECT `id` FROM `user` WHERE `username` = ? LIMIT 1");