MySQL: 정렬된 쿼리에서 행 번호 생성
정렬된 데이터세트로 작업하려면 명확한 순위를 위해 행 번호를 추가해야 하는 경우가 많습니다. Java와 같은 언어로 쿼리 후 처리가 가능하지만 MySQL은 효율적인 기본 처리를 위한 내장 솔루션을 제공합니다.
itemID
열이 있는 테이블을 상상해 보세요. 목표는 각 itemID
의 발생 횟수를 계산하는 것입니다. 기본 SQL 쿼리는 다음과 같습니다.
<code class="language-sql">SELECT itemID, COUNT(*) AS ordercount FROM orders GROUP BY itemID ORDER BY ordercount DESC;</code>
이 쿼리는 개수를 제공하지만 행 번호가 없습니다. MySQL의 @rank
변수가 이에 대한 해결책을 제공합니다. 순위 변수를 초기화하고 하위 쿼리 내에서 이를 증가시킵니다.
<code class="language-sql">SET @rank = 0;</code>
향상된 쿼리는 다음과 같습니다.
<code class="language-sql">SELECT @rank:=@rank+1 AS rank, itemID, COUNT(*) AS ordercount FROM orders GROUP BY itemID ORDER BY ordercount DESC;</code>
AS rank
생성된 순위를 새 열에 할당합니다.
최종 순위 값을 검색하려면(순위가 기본 결과 집합에 이미 포함되어 있으므로 불필요한 경우가 많음) 다음을 추가할 수 있습니다.
<code class="language-sql">SELECT @rank;</code>
이 방법은 정렬된 MySQL 쿼리에 행 번호 지정을 효율적으로 통합하여 데이터베이스 내에서 직접 순위가 지정된 데이터 분석을 단순화합니다.
위 내용은 정렬된 MySQL Select 문에 행 번호를 어떻게 추가할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!