>  기사  >  데이터 베이스  >  mysql에서 순위를 얻는 방법

mysql에서 순위를 얻는 방법

coldplay.xixi
coldplay.xixi원래의
2020-09-28 13:34:143327검색

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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