这是我关于StackOverflow的第一个问题,请你解释一下我做错了什么:我有这个代码(下面)但是由于某种原因,我试图调查和调试,我看不清楚为什么PDO没有完成下面的请求,它的插入和回显方式相同,有人可以告诉我发生了什么吗?我沮丧地把头发拉出脑袋。
$q = "UPDATE content SET urlid=:url, title=:title, description=:desc, keywords=:key WHERE urlid=:urlid";
$query = $pdo->prepare($q);
$query->execute(array(
':url' => $urlid,
':title' => $title,
':desc' => $desc,
':key' => $key,
':contloc' => $contloc,
':userid' => $uid,
':urlid' => $urlid
//':content' => $content
));
我在Apache错误日志中收到以下警告:
[Thu Jul 12 21:07:13 2012] [错误] [client 99.230.122.54] PHP警告:PDOStatement :: execute():SQLSTATE [HY093]:参数号无效:绑定变量数与数字不匹配第31行/Library/Server/Web/Data/Sites/Default/addto2.php中的令牌,引用:
http://localhost/sample/4fff30aea1f20
答案 0 :(得分:2)
$q = "UPDATE content SET urlid=:url, title=:title, description=:desc, keywords=:key WHERE urlid=:urlid";
$query = $pdo->prepare($q);
$query->execute(array(
':url' => $urlid,
':title' => $title,
':desc' => $desc,
':key' => $key,
':urlid' => $urlid
));
PDO抱怨是因为您传递的参数多于在查询中使用的参数。或许您打算在查询中包含更多参数而忘记了?