>데이터 베이스 >MySQL 튜토리얼 >DISTINCT는 ROW_NUMBER()와 어떻게 상호 작용하며 SQL에서 고유한 행 번호를 어떻게 얻을 수 있습니까?

DISTINCT는 ROW_NUMBER()와 어떻게 상호 작용하며 SQL에서 고유한 행 번호를 어떻게 얻을 수 있습니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-26 03:13:09463검색

How Does DISTINCT Interact with ROW_NUMBER() and How Can I Get Unique Row Numbers in SQL?

DISTINCT 키워드 및 ROW_NUMBER() 함수 이해

SQL에서 데이터를 작업할 때 고유한 행만 검색해야 하는 경우가 종종 있습니다. 테이블에서. DISTINCT 키워드는 결과 집합에서 중복 행을 제거하므로 일반적으로 이 목적으로 사용됩니다. 그러나 ROW_NUMBER() 함수와 결합하면 DISTINCT 키워드가 다르게 동작할 수 있습니다.

ROW_NUMBER() 함수 및 고유 값

ROW_NUMBER() 함수는 테이블의 각 행에 고유한 일련 번호를 부여합니다. 기본적으로 행은 테이블에서의 위치에 따라 정렬됩니다. 그러나 ORDER BY 절을 사용하여 다른 정렬 순서를 지정할 수 있습니다.

제공된 쿼리에서 ROW_NUMBER() 함수는 DISTINCT 키워드와 함께 사용됩니다.

SELECT DISTINCT id, ROW_NUMBER() OVER (ORDER BY id) AS RowNum
FROM table
WHERE fid = 64

이 쿼리는 id 열에 고유 값의 모든 행 번호를 표시합니다. 그러나 행 번호를 표시하지 않고 고유한 값만 반환합니다.

DENSE_RANK() 함수를 사용한 솔루션

원하는 결과를 얻으려면 DENSE_RANK( ) 함수를 ROW_NUMBER() 대신 사용하세요. DENSE_RANK() 함수는 행 순서에 관계없이 테이블의 각 고유 값에 고유한 일련 번호를 할당합니다.

DENSE_RANK()를 사용하여 수정된 쿼리:

SELECT DISTINCT id, DENSE_RANK() OVER (ORDER BY id) AS RowNum
FROM table
WHERE fid = 64

이 쿼리 원래 요구 사항을 충족하면서 해당 행 번호와 함께 id 열의 고유 값을 반환합니다.

위 내용은 DISTINCT는 ROW_NUMBER()와 어떻게 상호 작용하며 SQL에서 고유한 행 번호를 어떻게 얻을 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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