首頁 > Java > java教程 > 為什麼我的 JavaPreparedStatement 會拋出「參數索引超出範圍」?

為什麼我的 JavaPreparedStatement 會拋出「參數索引超出範圍」?

Mary-Kate Olsen
發布: 2024-12-25 21:31:09
原創
799 人瀏覽過

Why Does My Java PreparedStatement Throw

錯誤:「java.sql.SQLException:參數索引超出範圍(1 > 參數數量,即0)」

問題

您在嘗試將資料插入資料庫時遇到錯誤,並伴隨訊息「java.sql.SQLException:參數索引超出範圍(1 > 參數數量,為0)」。

原因

當您在 SQL 查詢中未指定佔位符 (?) 的情況下對PreparedStatement 呼叫 setXxx() 方法時,會發生此錯誤。例如:

String sql = "INSERT INTO tablename (col1, col2, col3) VALUES (val1, val2, val3)";
PreparedStatement preparedStatement = connection.prepareStatement(sql);
preparedStatement.setString(1, val1); // Error occurs here
登入後複製

解決方案

要解決此問題,請在SQL 查詢中包含佔位符:

String sql = "INSERT INTO tablename (col1, col2, col3) VALUES (?, ?, ?)";
PreparedStatement preparedStatement = connection.prepareStatement(sql);
preparedStatement.setString(1, val1);
登入後複製

請注意,參數索引從1開始,並且有無需在SQL 字串中引用佔位符。這樣做會導致同樣的錯誤。

其他資源

  • [JDBC 教學- 準備好的語句](https://docs.oracle.com/javase/tutorial/jdbc/基礎知識/prepared.html)

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

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