> 데이터 베이스 > MySQL 튜토리얼 > OutOfMemory 오류 없이 Spring에서 대규모 MySQL 결과 세트를 효율적으로 스트리밍하는 방법은 무엇입니까?

OutOfMemory 오류 없이 Spring에서 대규모 MySQL 결과 세트를 효율적으로 스트리밍하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-12-02 01:17:12
원래의
792명이 탐색했습니다.

How to Efficiently Stream Large MySQL Result Sets in Spring Without OutOfMemory Errors?

대규모 MySQL 결과 세트 스트리밍

문제 설명

대규모 MySQL 테이블을 로드할 때 Spring 애플리케이션, 드라이버가 전체 테이블을 메모리에 로드하려는 시도로 인해 OutOfMemory 예외가 발생합니다. 가져오기 크기를 Integer.MIN_VALUE로 설정했음에도 불구하고 ResultSet를 닫으면 정지 문제가 발생합니다. 작은 테이블의 경우에도 중단이 지속되어 연결이 닫히지 않아 다음과 같은 스택 추적이 발생합니다.

[Stack trace of the hang inserted here]
로그인 후 복사

해결 방법

가져오기 크기만 설정하는 것만으로는 충분하지 않습니다. MySQL JDBC 드라이버에는 특정 명령문 생성 방법이 필요합니다.

stmt = conn.createStatement(java.sql.ResultSet.TYPE_FORWARD_ONLY, java.sql.ResultSet.CONCUR_READ_ONLY);
stmt.setFetchSize(Integer.MIN_VALUE);
로그인 후 복사

주의 사항 및 의미

이 접근 방식에는 몇 가지 주의 사항이 있습니다.

  • 다른 쿼리를 실행하기 전에 결과 집합의 모든 행을 읽어야 합니다.
  • 잠금 트랜잭션 또는 문이 완료되거나 활성 결과 집합이 닫힐 때까지 해제되지 않습니다.

추가 고려 사항

OutOfMemory 예외가 지속되면 구현을 고려하세요. 과도한 메모리 할당을 피하기 위해 데이터베이스에서 검색된 데이터를 즉시 처리합니다. 이를 위해서는 상당한 코드 재구성과 다른 흐름 제어 접근 방식이 필요할 수 있습니다.

위 내용은 OutOfMemory 오류 없이 Spring에서 대규모 MySQL 결과 세트를 효율적으로 스트리밍하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿