>데이터 베이스 >MySQL 튜토리얼 >MySQL의 각 범주에서 무작위 레코드를 선택하는 방법은 무엇입니까?

MySQL의 각 범주에서 무작위 레코드를 선택하는 방법은 무엇입니까?

DDD
DDD원래의
2024-12-26 15:55:14556검색

How to Select a Random Record from Each Category in 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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