$criteria = new CDbCriteria(); $criteria->addCondition("customid = :customid"); $criteria->params= array(':customid'=>$customid); if(trim($groupid)!=""){ $criteria->addCondition ('groupid' = :groupid);
<pre name="code" class="php"><span style="white-space:pre"> </span>$criteria->params= array(':groupid'=>$groupid);
<span style="white-space:pre"> </span>}
<span style="white-space:pre"> </span>
invalid parameter number: number of bound variables does not match number of tokens.
这个报错的意思是你查询的条件和参数个数不相符;
如果自信观察下我上面的代码,会发现有个大意的错误了的,加入我符合goupid的条件,那么最终我的参数就只有一个,就是 :goupid,而全线的:customid =$customid就会被覆盖了,所以解决的办法就是在goupid条件语句里面做个更改:
$criteria->params= array(':customid'=>$customid,':groupid'=>$groupid);
或者使用这种写法会更好:
<span style="white-space:pre"> </span>$criteria = new CDbCriteria(); $criteria->addCondition("customid = :customid"); $criteria->params[':customid'] = $customid; if(trim($groupid)!=""){ $criteria->addCondition ("groupid = :groupid"); $criteria->params[':groupid'] = $groupid; }
以上就介绍了Invalid parameter number: number of bound variables does not match number of tokens,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号