>데이터 베이스 >MySQL 튜토리얼 >Java JDBC에서 \'java.sql.SQLException: ResultSet이 닫힌 후 작업이 허용되지 않음\'이 발생하는 이유는 무엇입니까?

Java JDBC에서 \'java.sql.SQLException: ResultSet이 닫힌 후 작업이 허용되지 않음\'이 발생하는 이유는 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-29 19:01:02849검색

Why Am I Getting

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.