首頁 >資料庫 >mysql教程 >為什麼我的 Java 程式碼會拋出「參數索引超出範圍」SQL 異常?

為什麼我的 Java 程式碼會拋出「參數索引超出範圍」SQL 異常?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-12-27 00:48:17676瀏覽

Why Does My Java Code Throw a

SQL 異常中參數索引超出範圍:原因及解決方案

遇到例外「java.sql.SQLException: Parameter index out of資料庫插入期間「範圍(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 查詢字串以包含您想要的所有參數的佔位符(?)

修正程式碼範例:

注意:

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開始.您應該避免在佔位符周圍使用單引號或雙引號。

    其他資訊:
  • [JDBC 教學-準備好聲明了](https://docs.oracle.com/javase/7/docs/technotes/guides/jdbc/index.html#prepared)

以上是為什麼我的 Java 程式碼會拋出「參數索引超出範圍」SQL 異常?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn