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

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

Mary-Kate Olsen
發布: 2024-12-27 00:48:17
原創
666 人瀏覽過

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中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板