mysql에서 순위를 얻는 방법: 데모 기능을 사용합니다. 구문은 [SELECT banji,avg(score) as AvgS FROM table_test GROUP BY banji ORDER BY AvgS DESC]입니다.
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!