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

Patricia Arquette
リリース: 2024-10-22 11:02:29
オリジナル
806 人が閲覧しました

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 サイトの他の関連記事を参照してください。

ソース:php
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!