MySQL 데이터베이스에서 대규모 결과 세트로 작업할 때 메모리 소비가 문제가 될 수 있습니다. MySQLDB 라이브러리는 이 문제를 완화하기 위해 SScursor 클래스를 제공하여 대용량 데이터 볼륨을 보다 효율적으로 처리할 수 있는 방법을 제공합니다.
fetchall()의 메모리 사용량
인기 있는 것과는 반대로 기본 커서와 SScursor 모두에서 fetchall()을 실행하면 동일한 양의 메모리가 소비됩니다. 전체 결과 집합을 메모리에 보관할 수 있을 만큼 큰 버퍼를 할당합니다.
SScursor로 스트리밍
SScursor의 장점은 결과를 로드하지 않고 결과를 반복할 수 있는 능력에 있습니다. 전체 데이터 세트를 메모리에 저장합니다. SScursor로 스트리밍을 달성하려면:
<code class="python">def stream_rows(cursor): for row in cursor: yield row</code>
<code class="python">for row in cursor: # Process row</code>
가장 효율적인 스트리밍 방법
가장 효율적인 스트리밍 방법은 추가 루프의 오버헤드를 피하기 위해 생성기를 사용하는 것입니다. 생성기는 다른 함수에 전달되거나 처리 및 필터링 작업에 직접 사용될 수 있습니다.
위 내용은 MySQLDB의 SScursor를 사용하여 대규모 결과 세트를 효율적으로 스트리밍하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!