대형 MySQL 테이블에서 무작위 행 선택 최적화
대형 MySQL 테이블에서 임의의 단일 행을 효율적으로 검색하는 것은 많은 애플리케이션에 필수적입니다. 일반적인 접근 방식은 모든 행 ID를 가져와서 무작위로 선택한 다음 해당 행을 검색하는 것입니다.
순차 ID가 있고 간격이 없는 테이블의 경우 최대 ID를 찾고 해당 범위 내에서 임의 ID를 생성하면 빠른 솔루션을 제공합니다. 그러나 간격이 존재하지만 상대적으로 빈도가 낮은 경우 약간 덜 무작위이지만 여전히 실용적인 방법은 간격 수를 추정하고, 최대 ID를 얻고, 무작위 ID를 계산하고, 계산된 ID보다 크거나 같은 ID를 가진 첫 번째 행을 검색하는 것입니다. 값입니다.
중요하게, 무작위 행 선택에 ORDER BY RAND()
를 사용하지 마세요. 이 방법을 사용하면 전체 테이블 스캔이 발생하여 빠른 검색 목적이 무산되는 경우가 많습니다. 마찬가지로 주문 시 GUID를 사용하는 것도 마찬가지로 비효율적입니다.
위 내용은 대규모 MySQL 테이블에서 임의의 행을 빠르게 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!