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);
修正程式碼範例:
注意:
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開始.您應該避免在佔位符周圍使用單引號或雙引號。
以上是為什麼我的 Java 程式碼會拋出「參數索引超出範圍」SQL 異常?的詳細內容。更多資訊請關注PHP中文網其他相關文章!