집 >데이터 베이스 >MySQL 튜토리얼 >MySQL의 각 범주에서 무작위 레코드를 선택하는 방법은 무엇입니까?
MySQL의 각 범주에서 무작위 레코드 선택
이 데이터베이스 쿼리에는 테이블의 각 범주에서 무작위 레코드를 선택하는 작업이 포함됩니다. 제공된 테이블에는 "id", "name" 및 "category" 열이 있는 "Items" 테이블이 포함되어 있습니다. 각 항목은 "id" 및 "category" 열이 있는 "Categories" 테이블에 표시된 7개 범주 중 하나에 속합니다.
이 쿼리에 효과적으로 접근하려면 조인과 RAND() 함수를 조합하여 사용할 수 있습니다. . 작업을 수행하는 쿼리는 다음과 같습니다.
SELECT * FROM ( SELECT c.id AS cid, c.category, i.id AS iid, i.name FROM categories c INNER JOIN items i ON c.id = i.category ORDER BY RAND() ) AS shuffled_items GROUP BY cid
이 쿼리는 먼저 "범주" 열의 "범주" 및 "항목" 테이블을 조인하여 모든 항목과 해당 범주를 검색합니다. ORDER BY RAND() 절은 결과에 무작위 순서를 적용합니다. 이후 쿼리는 하위 쿼리로 래핑되고 "cid" 열로 그룹화됩니다. 이 그룹화를 통해 각 범주는 단일 임의 레코드로 제한됩니다.
큰 테이블의 경우 성능 최적화가 필요할 수 있습니다. 쿼리가 느리게 실행되는 경우 MySQL의 임시 테이블을 사용하거나 "범주" 열에 인덱스를 생성하는 것이 좋습니다.
위 내용은 MySQL의 각 범주에서 무작위 레코드를 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!