MySQL을 사용하여 대규모 결과 세트 스트리밍
Spring 애플리케이션 내에서 광범위한 MySQL 테이블을 처리할 때 드라이버가 다음을 수행하려고 하면 OutOfMemoryException이 발생할 수 있습니다. 전체 테이블을 메모리에 로드합니다. 설정문.setFetchSize(Integer.MIN_VALUE); 이는 단순히 JDBC 드라이버에 대한 힌트를 제공하기 때문에 충분하지 않을 수 있습니다.
MySQL JDBC 드라이버에서 결과 세트 스트리밍을 활성화하려면 보다 포괄적인 접근 방식이 필요합니다.
성명서 작성 인스턴스:
stmt = conn.createStatement(java.sql.ResultSet.TYPE_FORWARD_ONLY, java.sql.ResultSet.CONCUR_READ_ONLY);
가져오기 크기 설정:
stmt.setFetchSize(Integer.MIN_VALUE);
주의 사항 :
이 방법은 특정 주의 사항:
추가 통찰력:
대규모 결과 집합 처리에 대한 추가 전략을 알아보려면 다음 관련 질문과 답변을 고려하세요. [비슷한 질문 링크].
위 내용은 OutOfMemoryError를 피하기 위해 Spring에서 대규모 MySQL 결과 세트를 스트리밍하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!