>데이터 베이스 >MySQL 튜토리얼 >대규모 MySQL 테이블에서 임의의 행을 빠르게 검색하려면 어떻게 해야 합니까?

대규모 MySQL 테이블에서 임의의 행을 빠르게 검색하려면 어떻게 해야 합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-19 07:16:13281검색

How Can I Quickly Retrieve a Random Row from a Large MySQL Table?

대형 MySQL 테이블에서 무작위 행 선택 최적화

대형 MySQL 테이블에서 임의의 단일 행을 효율적으로 검색하는 것은 많은 애플리케이션에 필수적입니다. 일반적인 접근 방식은 모든 행 ID를 가져와서 무작위로 선택한 다음 해당 행을 검색하는 것입니다.

순차 ID가 있고 간격이 없는 테이블의 경우 최대 ID를 찾고 해당 범위 내에서 임의 ID를 생성하면 빠른 솔루션을 제공합니다. 그러나 간격이 존재하지만 상대적으로 빈도가 낮은 경우 약간 덜 무작위이지만 여전히 실용적인 방법은 간격 수를 추정하고, 최대 ID를 얻고, 무작위 ID를 계산하고, 계산된 ID보다 크거나 같은 ID를 가진 첫 번째 행을 검색하는 것입니다. 값입니다.

중요하게, 무작위 행 선택에 ORDER BY RAND()를 사용하지 마세요. 이 방법을 사용하면 전체 테이블 스캔이 발생하여 빠른 검색 목적이 무산되는 경우가 많습니다. 마찬가지로 주문 시 GUID를 사용하는 것도 마찬가지로 비효율적입니다.

위 내용은 대규모 MySQL 테이블에서 임의의 행을 빠르게 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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