>  기사  >  백엔드 개발  >  MySQL에서 가중치가 부여된 무작위 항목을 어떻게 선택할 수 있습니까?

MySQL에서 가중치가 부여된 무작위 항목을 어떻게 선택할 수 있습니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-23 13:49:10169검색

How Can I Select a Weighted Random Entry in MySQL?

MySQL: 가중치가 적용된 무작위 항목 선택

문제:

MySQL 테이블에 가중치를 할당하는 "승수" 열이 포함되어 있습니다. 항목에. 작업은 이러한 가중치를 고려하면서 무작위 항목을 선택하는 것입니다.

해결책:

RAND()는 무작위 항목을 선택하는 데 도움이 되지만 선택 항목에 가중치를 부여하려면 혁신적인 방법이 필요합니다. 접근하다. 답은 균형 잡힌 가중치를 보장하기 위해 테이블 ​​설정을 수정하는 데 있습니다.

전문가에 따르면 ORDER BY -LOG(1.0 - RAND()) / Multiplier를 사용하는 쿼리는 가중치 선택을 효과적으로 달성합니다. 이 공식의 수학적 근거는 즉시 명백하지 않지만 정확한 결과를 산출한다는 것이 경험적으로 입증되었습니다.

그러나 이 접근 방식에는 한계가 있습니다. 항목을 비활성화하기 위해 항목에 가중치 0을 할당하면 0으로 나누게 됩니다. 이 문제를 피하려면 WHERE 절을 활용하여 승수가 0보다 큰 항목을 필터링할 수 있습니다.

위 내용은 MySQL에서 가중치가 부여된 무작위 항목을 어떻게 선택할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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