ホームページ >データベース >mysql チュートリアル >プリペアドステートメントでテーブル名のパラメータ化が失敗するのはなぜですか?
準備されたステートメントのパラメーター エラーの解決: テーブル名の場合
プリペアドステートメントを使用したデータベースクエリでは、慎重なパラメータ処理が必要です。 パラメーターを使用してテーブル名自体を指定しようとすると、一般的なエラーが発生します。
エラー メッセージ「テーブル名が必要な場所に Microsoft パラメーター 'Pa_RaM000' が指定されました」は、この制限を強調しています。プリペアド ステートメントは、データ値 (数値、文字列など) のパラメーター化には優れていますが、パラメーター化されたテーブル名を処理することはできません。
解決策は簡単です。テーブル名を SQL クエリに直接埋め込みます。 テーブル名にパラメータ プレースホルダを使用することは避けてください。 代わりに、テーブル名をクエリ文字列に連結します。
修正されたコードは次のとおりです:
<code class="language-sql">private String query1 = "SELECT plantID, edrman, plant, vaxnode FROM [" + reportDate + "]";</code>
この改訂されたアプローチでは、reportDate
が FROM
句に直接組み込まれており、パラメーター置換エラーが排除され、準備されたステートメントが正しく実行できるようになります。
以上がプリペアドステートメントでテーブル名のパラメータ化が失敗するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。