您在嘗試將資料插入資料庫時遇到錯誤,並伴隨訊息「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 字串中引用佔位符。這樣做會導致同樣的錯誤。
以上是為什麼我的 JavaPreparedStatement 會拋出「參數索引超出範圍」?的詳細內容。更多資訊請關注PHP中文網其他相關文章!