首页  >  文章  >  后端开发  >  如何解决 mysqli_bind_param() 中的“变量数量与参数数量不匹配”问题?

如何解决 mysqli_bind_param() 中的“变量数量与参数数量不匹配”问题?

Susan Sarandon
Susan Sarandon原创
2024-10-22 12:46:02468浏览

How to Troubleshoot

理解 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();

现在,准备好的语句有一个 ?每个变量、年份和品牌的占位符。

要记住的要点

  • 在准备好的语句中,问号是值的占位符。
  • 不要将占位符括在引号中。
  • 准备好的语句中的占位符数量必须与使用bind_param()绑定的变量数量相对应。

以上是如何解决 mysqli_bind_param() 中的“变量数量与参数数量不匹配”问题?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn