>데이터 베이스 >SQL >SQL에서 순위(over()를 사용하는 방법

SQL에서 순위(over()를 사용하는 방법

下次还敢
下次还敢원래의
2024-05-09 07:42:18766검색

SQL의 RANK() OVER() 함수는 데이터 레코드에 순위 값을 할당하는 데 사용됩니다. 순위를 매길 열과 정렬 순서를 지정하는 ORDER BY 절을 허용합니다. 매개변수에는 열 이름(순위를 매길 열), 정렬 순서(오름차순 또는 내림차순), NULL 값 처리 방법(첫 번째, 마지막 또는 NULL이 아닌 값만)이 포함됩니다. 이 함수는 동일한 값을 갖는 레코드에 동일한 순위 또는 고유 순위를 할당하는 데 사용되며, NULL 값을 제외하거나 처리할 수 있습니다.

SQL에서 순위(over()를 사용하는 방법

RANK() OVER() SQL에서의 사용법

RANK() OVER() 함수는 SQL에서 데이터 순위를 지정하고 각 레코드에 순위 값을 할당하는 데 사용됩니다. 이 함수는 순위를 매길 열과 정렬 순서를 지정하는 ORDER BY 절을 허용합니다.

구문: ​​

<code>RANK() OVER (ORDER BY 列名 [ASC|DESC] [NULLS FIRST|LAST|ONLY])</code>

매개변수:

  • 열 이름: 순위에 참여할 열을 지정합니다.
  • ASC|DESC: 순위 순서(오름차순 또는 내림차순)를 지정합니다.
  • NULLS FIRST|LAST|ONLY: NULL 값을 처리하는 방법을 지정합니다.

사용법:

RANK() OVER() 함수는 다음을 포함하여 데이터에 대해 다양한 유형의 순위를 지정하는 데 사용됩니다.

  • 동일한 값을 가진 레코드에 동일한 순위 할당
  • 서로 다른 레코드에 고유성 할당 값 Ranking
  • NULL 값 제외 또는 NULL 값 순위 첫 번째/마지막

예:

다음 예에서는 "Score" 열을 기반으로 "Students" 테이블의 레코드 순위를 높은 것부터 높은 것까지 순위를 매깁니다. 낮음:

<code>SELECT *, RANK() OVER (ORDER BY 分数 DESC) AS 排名
FROM 学生;</code>

결과는 다음과 같습니다:

ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋ 4참고: RANK () OVER() Return 순위 값은 0이 아닌 1부터 시작합니다. 순위를 매기는 열에 동일한 값을 가진 레코드가 여러 개 있는 경우 이러한 레코드에는 동일한 순위 값이 할당됩니다. NULL 값의 경우 NULLS FIRST 옵션은 NULL 값의 순위를 먼저 지정하고, NULLS LAST 옵션은 NULL 값의 순위를 마지막으로 지정하며, NULLS ONLY 옵션은 NULL이 아닌 값의 순위를 지정합니다.
학생 번호 Name Score Ranking
1 Xiao Ming 95 1
2

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

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