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