> 데이터 베이스 > MySQL 튜토리얼 > mysql에서 순위를 얻는 방법

mysql에서 순위를 얻는 방법

coldplay.xixi
풀어 주다: 2020-09-28 13:34:14
원래의
3381명이 탐색했습니다.

mysql에서 순위를 얻는 방법: 데모 기능을 사용합니다. 구문은 [SELECT banji,avg(score) as AvgS FROM table_test GROUP BY banji ORDER BY AvgS DESC]입니다.

mysql에서 순위를 얻는 방법

mysql에서 순위를 얻는 방법:

는 Demo로 구현할 수 있습니다

여기에 있는 A는 중첩 쿼리이므로 순위가 정확합니다.

FROM
(
     SELECT A.*,@rank:=@rank+1 as pm
     FROM 
     (
      SELECT banji,avg(score) as AvgS FROM table_test GROUP BY banji  ORDER BY AvgS   DESC
     ) A ,(SELECT @rank:=0) B
) M
ORDER BY M.banji
로그인 후 복사

서브 쿼리가 없고 다음 SQL을 사용하면 정렬이 잘못됩니다. 문제는 GROUP BY에 둘 이상의 그룹이 있는지 여부에 따라 다릅니다.

SELECT banji,avg(score) as AvgS ,@rank:=@rank+1 as pm
FROM table_test A,(SELECT @rank:=0) B
GROUP BY banji
ORDER BY AvgS   DESC
로그인 후 복사

이유: @rank 순위는 GROUP BY 이전에 발생합니다. GROUP BY는 순위가 매겨진 결과를 그룹화합니다. 그룹화된 결과의 순위를 지정하려면 하위 쿼리를 사용하세요.

더 많은 관련 무료 학습 권장사항: mysql 튜토리얼(동영상)

위 내용은 mysql에서 순위를 얻는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿