ホームページ > バックエンド開発 > PHPチュートリアル > PDO の「bindParam」が定数で失敗するのはなぜですか?「パラメータ 2 を参照で渡せません」エラーを修正するにはどうすればよいですか?

PDO の「bindParam」が定数で失敗するのはなぜですか?「パラメータ 2 を参照で渡せません」エラーを修正するにはどうすればよいですか?

Linda Hamilton
リリース: 2024-11-20 14:29:16
オリジナル
548 人が閲覧しました

Why Does PDO's `bindParam` Fail with Constants, and How Can I Fix the

定数を含む PDO bindingParam での「パラメータ 2 を参照で渡せません」エラーのトラブルシューティング

PDO を使用しているときに、開発者は不可解なエラーに遭遇する可能性があります「パラメーター 2 を参照によって渡すことはできません。」これは通常、bindParam を定数値で使用するときに発生します。

この問題を修正するには、bindParam の使用から bindingValue への切り替えが重要です。 bindParam は変数を参照として受け取り、ステートメントの実行中にその値のみを補間します。対照的に、bindValue は指定された値をすぐに評価し、それをステートメントに組み込みます。

次の例は、bindValue の正しい使用法を示しています。

$stmt = $dbh->prepare('INSERT INTO table(v1, v2, ...) VALUES(:v1, :v2, ...)');
$stmt->bindValue(':v1', null, PDO::PARAM_INT);
ログイン後にコピー

null のような定数値をバインドする場合は、 PDO::PARAM_NULL ではなく、PDO::PARAM_INT または別の適切な PDO::PARAM タイプを使用して実行できます。

この簡単な調整に従うことで、開発者は「パラメータ 2 を参照で渡せません」エラーを効果的に解決できます。データベース操作は支障なく続行できます。

以上がPDO の「bindParam」が定数で失敗するのはなぜですか?「パラメータ 2 を参照で渡せません」エラーを修正するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート