집 >데이터 베이스 >MySQL 튜토리얼 >Java JDBC에서 \'java.sql.SQLException: ResultSet이 닫힌 후 작업이 허용되지 않음\'이 발생하는 이유는 무엇입니까?
Java: 연결 종료 후 ResultSet 사용 시 오류
JDBC를 사용하여 MySQL 데이터베이스에서 데이터를 검색하려고 하면 사용자에게 다음 오류가 발생할 수 있습니다. "java.sql.SQLException: ResultSet이 닫힌 후에는 작업이 허용되지 않습니다." 이는 기본 연결이 닫힌 후 ResultSet 객체를 사용하려고 할 때 발생합니다.
설명
JDBC는 지연 로딩 개념으로 작동합니다. 쿼리는 요청될 때까지 완전히 검색되지 않습니다. ResultSet 개체는 결과 위에 커서를 제공하여 결과를 반복할 수 있도록 합니다. 그러나 ResultSet을 생성한 연결을 닫으면 커서도 닫혀 사용할 수 없게 됩니다.
해결 방법
이 오류를 방지하려면 다음 중 하나를 수행해야 합니다. ResultSet은 더 이상 필요하지 않거나 다른 접근 방식을 사용합니다.
권장되는 접근 방식 중 하나는 행 매퍼를 사용하여 결과 집합을 개체 컬렉션으로 변환하는 것입니다. 이 방법은 변환 프로세스를 캡슐화하고 연결이 닫힌 후에도 결과에 액세스할 수 있도록 허용합니다.
<code class="java">public static List<T> sqlquery(String query, RowMapper<T> rowMapper) throws SQLException { try (Connection connection = DriverManager.getConnection(...); Statement st = connection.createStatement(); ResultSet rs = st.executeQuery(query)) { List<T> list = new ArrayList<>(); while (rs.next()) { list.add(rowMapper.mapRow(rs)); } return list; } }</code>
이 수정된 코드는 try-with-resources를 사용하여 연결, 문 및 결과 집합이 올바른지 확인합니다. 메소드가 완료되면 자동으로 닫히므로 수동으로 닫는 것을 잊어버릴 가능성이 없습니다. 또한 행 매퍼를 사용하여 결과 집합의 각 행을 채워진 개체로 변환한 다음 목록으로 수집할 수 있습니다.
결론
이해함으로써 JDBC의 지연 로딩 메커니즘과 행 매퍼를 활용하여 개발자는 연결 종료 후 닫힌 ResultSet과 관련된 오류를 피하면서 데이터베이스에서 데이터를 효과적으로 검색할 수 있습니다.
위 내용은 Java JDBC에서 \'java.sql.SQLException: ResultSet이 닫힌 후 작업이 허용되지 않음\'이 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!