理解 mysqli_bind_param() 中的“变量数量与参数数量不匹配”错误
在 MySQL 的 mysqli 中使用准备好的语句时扩展中,确保参数的绑定与准备好的查询语法一致至关重要。如果不这样做,可能会导致类似“变量数量与准备好的语句中的参数数量不匹配”的错误。
让我们深入研究提供的代码片段以找出问题:
$stmt = $mysqli->prepare("SELECT DISTINCT model FROM vehicle_types WHERE year = ? AND make = '?' ORDER by model"); $stmt->bind_param('is', $year, $make); $stmt->execute();
出现错误的原因是准备好的语句包含用引号引起来的 make 值的占位符:“?'”。在准备好的语句中,问号用作稍后绑定的值的占位符。但是,当它们用引号括起来时,它们将被视为文字文本而不是占位符。
更正准备好的语句
要解决此问题,请删除周围的引号这 ?准备好的语句中 make 的占位符:
$stmt = $mysqli->prepare("SELECT DISTINCT model FROM vehicle_types WHERE year = ? AND make = ? ORDER by model"); $stmt->bind_param('is', $year, $make); $stmt->execute();
现在,准备好的语句有一个 ?每个变量、年份和品牌的占位符。
要记住的要点
以上是如何解决 mysqli_bind_param() 中的'变量数量与参数数量不匹配”问题?的详细内容。更多信息请关注PHP中文网其他相关文章!