JDBC ResultSet 問題:「Before Start of Result Set」例外
嘗試從ResultSet 物件擷取資料時,可能會發生錯誤說明「在結果集開始之前」。此錯誤通常是由於 ResultSet 中的遊標定位問題而造成的。
在提供的程式碼片段中,使用 result.beforeFirst() 將 ResultSet 定位在第一行之前。隨後,嘗試使用 result.getString(1) 檢索數據,而不先將遊標移到有效行。
要解決此問題,在嘗試檢索之前應將遊標定位到第一行資料。這可以透過使用 result.next() 或 result.first() 方法來實現。
修正程式碼:
ResultSet result = prep.executeQuery(); result.next(); // Move the cursor to the first row String foundType = result.getString(1);
或者,如果不確定是否如果ResultSet 包含任何數據,則可以使用if 語句在嘗試移動結果集之前檢查資料遊標:
if (result.next()) { String foundType = result.getString(1); }
在取得資料之前確保遊標定位到有效行,可以避免「Before start of result set」異常,從而成功從ResultSet中取得資料。
以上是為什麼我在 JDBC 中收到「結果集啟動之前」異常?的詳細內容。更多資訊請關注PHP中文網其他相關文章!