ホームページ >データベース >mysql チュートリアル >Java コードで「パラメーター インデックスが範囲外」という SQL 例外がスローされるのはなぜですか?

Java コードで「パラメーター インデックスが範囲外」という SQL 例外がスローされるのはなぜですか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2024-12-27 00:48:17669ブラウズ

Why Does My Java Code Throw a

SQL 例外のパラメータ インデックスが範囲外です: 原因と解決策

例外「java.sql.SQLException: パラメータ インデックスが範囲外です」が発生しましたデータベースの挿入中に「範囲 (1 > パラメータの数、つまり 0)」というメッセージが表示されるとイライラすることがあります。このエラーは、SQL クエリにそれらのパラメータに対応するプレースホルダ (?) がないときに準備されたステートメントにパラメータ値を設定しようとすると発生します。

エラーの原因:

このエラーは、PreparedStatement で setXxx() メソッドを使用しようとしたが、SQL クエリ文字列に指定されたパラメータに必要なプレースホルダがない場合に発生します。 Index.

間違ったコードの例:

String sql = "INSERT INTO tablename (col1, col2, col3) VALUES (val1, val2, val3)";

preparedStatement = connection.prepareStatement(sql);
preparedStatement.setString(1, val1); // This will fail.
preparedStatement.setString(2, val2);
preparedStatement.setString(3, val3);

解決策:

この問題を解決するには、次のことを行う必要があります。 SQL クエリ文字列を変更して、対象とするすべてのパラメータのプレースホルダ (?) を含めます。 set.

修正コードの例:

String sql = "INSERT INTO tablename (col1, col2, col3) VALUES (?, ?, ?)";

preparedStatement = connection.prepareStatement(sql);
preparedStatement.setString(1, val1);
preparedStatement.setString(2, val2);
preparedStatement.setString(3, val3);

注:

  • パラメータのインデックスは 1 から始まります.
  • 一重引用符または二重引用符で囲むことは避けてください。プレースホルダー。これを行うと、SQL パーサーがそれらを文字列値として解釈し、同じ例外が発生します。

追加情報:

  • [JDBC チュートリアル] - 準備したステートメント](https://docs.oracle.com/javase/7/docs/technotes/guides/jdbc/index.html#prepared)

以上がJava コードで「パラメーター インデックスが範囲外」という SQL 例外がスローされるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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