重用語句連接前關閉ResultSet
在Java資料庫程式設計中,偶爾會遇到關閉後使用prepared語句時出現的異常結果集。當使用相同的連接物件時,特別會出現「ResultSet 關閉後不允許操作」的例外狀況。
在給定的程式碼片段中,在關閉現有 ResultSet 後,使用相同的連接物件建立一個新的準備好的語句(rs 和 rs2)。這引發了異常。要解決此問題並重複使用語句連接,最佳實踐是先確保與該語句關聯的所有先前 ResultSet 都已關閉。
一種建議的方法是使用 try-with-resources 區塊,它會自動關閉 ResultSet和聲明。以下是範例:
try ( Statement statement = connection.createStatement(); ResultSet rs = statement.executeQuery("SELECT `name` FROM `user` WHERE `id` = " + userId + " LIMIT 1;") ) { if (rs.next()) { // Process the results } try ( ResultSet rs2 = statement.executeQuery("SELECT `id` FROM `profiles` WHERE `id` =" + profId + ";") ) { String updateSql = "INSERT INTO `blah` ..."; PreparedStatement pst = (PreparedStatement) connection.prepareStatement(updateSql); while (rs2.next()) { // ... } pst.executeBatch(); } } catch (SQLException e) { e.printStackTrace(); }
在此範例中,在嘗試使用 Statement 準備新批次之前,rs 和 rs2 在各自的 try 區塊內關閉。這可確保在執行準備好的語句之前沒有開啟的 ResultSet。
請記住,維護活動的 ResultSet 物件對於正確的資料庫互動至關重要。始終優先考慮適當的資源處理和清理,以避免異常並確保資料完整性。
以上是為什麼Java重用語句連接時出現「ResultSet關閉後不允許操作」的情況?的詳細內容。更多資訊請關注PHP中文網其他相關文章!