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 중국어 웹사이트의 기타 관련 기사를 참조하세요!