문제:
MySQL 테이블에 가중치를 할당하는 "승수" 열이 포함되어 있습니다. 항목에. 작업은 이러한 가중치를 고려하면서 무작위 항목을 선택하는 것입니다.
해결책:
RAND()는 무작위 항목을 선택하는 데 도움이 되지만 선택 항목에 가중치를 부여하려면 혁신적인 방법이 필요합니다. 접근하다. 답은 균형 잡힌 가중치를 보장하기 위해 테이블 설정을 수정하는 데 있습니다.
전문가에 따르면 ORDER BY -LOG(1.0 - RAND()) / Multiplier를 사용하는 쿼리는 가중치 선택을 효과적으로 달성합니다. 이 공식의 수학적 근거는 즉시 명백하지 않지만 정확한 결과를 산출한다는 것이 경험적으로 입증되었습니다.
그러나 이 접근 방식에는 한계가 있습니다. 항목을 비활성화하기 위해 항목에 가중치 0을 할당하면 0으로 나누게 됩니다. 이 문제를 피하려면 WHERE 절을 활용하여 승수가 0보다 큰 항목을 필터링할 수 있습니다.
위 내용은 MySQL에서 가중치가 부여된 무작위 항목을 어떻게 선택할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!