> 데이터 베이스 > MySQL 튜토리얼 > ORDER BY RAND()를 사용하여 MySQL 쿼리를 어떻게 최적화할 수 있습니까?

ORDER BY RAND()를 사용하여 MySQL 쿼리를 어떻게 최적화할 수 있습니까?

Linda Hamilton
풀어 주다: 2024-12-14 02:38:14
원래의
674명이 탐색했습니다.

How Can I Optimize MySQL Queries Using ORDER BY RAND()?

MySQL RAND() 주문 최적화

ORDER BY RAND()를 사용하는 느린 쿼리는 성능 문제를 야기합니다.

문제

쿼리 ORDER BY RAND()를 사용하면 특히 크거나 자주 업데이트되는 테이블에서 최적의 성능을 발휘하지 못하는 경우가 많습니다. MySQL의 솔루션(MySQLPerformanceBlog)은 충분하지 않을 수 있습니다.

솔루션

RAND() 순서를 최적화하려면 다음 접근 방식을 고려하세요.

SELECT  *
FROM    (
        SELECT  @cnt := COUNT(*) + 1,
                @lim := 10
        FROM    t_random
        ) vars
STRAIGHT_JOIN
        (
        SELECT  r.*,
                @lim := @lim - 1
        FROM    t_random r
        WHERE   (@cnt := @cnt - 1)
                AND RAND(20090301) < @lim / @cnt
        ) i
로그인 후 복사

이 접근 방식은 데이터를 반복하는 동안 실행 확률을 유지하여 정렬을 피하므로 ORDER BY보다 효율적입니다. RAND().

단일 행 선택의 경우

단일 임의 행을 선택하려면 다음 쿼리를 시도하십시오.

SELECT  aco.*
FROM    (
        SELECT  minid + FLOOR((maxid - minid) * RAND()) AS randid
        FROM    (
                SELECT  MAX(ac_id) AS maxid, MIN(ac_id) AS minid
                FROM    accomodation
                ) q
        ) q2
JOIN    accomodation aco
ON      aco.ac_id =
        COALESCE
        (
        (
        SELECT  accomodation.ac_id
        FROM    accomodation
        WHERE   ac_id > randid
                AND ac_status != 'draft'
                AND ac_images != 'b:0;'
                AND NOT EXISTS
                (
                SELECT  NULL
                FROM    accomodation_category
                WHERE   acat_id = ac_category
                        AND acat_slug = 'vendeglatohely'
                )
        ORDER BY
                ac_id
        LIMIT   1
        ),
        (
        SELECT  accomodation.ac_id
        FROM    accomodation
        WHERE   ac_status != 'draft'
                AND ac_images != 'b:0;'
                AND NOT EXISTS
                (
                SELECT  NULL
                FROM    accomodation_category
                WHERE   acat_id = ac_category
                        AND acat_slug = 'vendeglatohely'
                )
        ORDER BY
                ac_id
        LIMIT   1
        )
        )
로그인 후 복사

이 최적화에서는 다음을 가정합니다. ac_id는 상대적으로 고르게 분포되어 있습니다.

위 내용은 ORDER BY RAND()를 사용하여 MySQL 쿼리를 어떻게 최적화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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