ホームページ  >  記事  >  バックエンド開発  >  準備されたステートメントのバインディング パラメーター番号の不一致を解決するにはどうすればよいですか?

準備されたステートメントのバインディング パラメーター番号の不一致を解決するにはどうすればよいですか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-10-22 11:02:29807ブラウズ

How to Resolve Binding Parameter Number Mismatch in Prepared Statements?

"bind_param 変数の数が準備されたステートメントのパラメーターの数と一致しません"

提供されたコード スニペットで発生した警告は、 bind_param() メソッド内の変数の数と、準備されたステートメント内のパラメータの数。この問題を解決するには、これら 2 つの数値が一致していることを確認することが重要です。

最初に使用した準備済みステートメント:

$stmt = $mysqli->prepare("SELECT DISTINCT model FROM vehicle_types 
    WHERE year = ? AND make = '?' ORDER by model");

にはエラーが含まれています。 make パラメータのプレースホルダが誤って引用符 (「?」) で囲まれています。プリペアド ステートメントでは、プレースホルダーは引用符なしの疑問符で表す必要があります。

修正されたプリペアド ステートメント:

$stmt = $mysqli->prepare("
    SELECT DISTINCT model FROM vehicle_types WHERE year = ? AND make = ? ORDER by model
");

には、bind_param() メソッドの 2 つの変数と一致する 2 つのプレースホルダーが含まれています。

$stmt->bind_param('is', $year, $make);

make プレースホルダーの周囲の誤った引用符を削除することで、変数とパラメーターの数を揃え、不一致エラーを解決します。

以上が準備されたステートメントのバインディング パラメーター番号の不一致を解決するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。