>데이터 베이스 >MySQL 튜토리얼 >SQL에서 고유한 값에 행 번호를 할당하는 방법은 무엇입니까?

SQL에서 고유한 값에 행 번호를 할당하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-29 20:52:16484검색

How to Assign Row Numbers to Distinct Values in SQL?

Row_Number를 사용하는 SQL의 고유 행 번호

SQL의 고유 쿼리는 지정된 열에서 고유 값을 검색하는 데 사용됩니다. 그러나 고유한 값뿐만 아니라 해당 행 번호도 표시하는 것이 바람직한 시나리오가 있습니다. 이를 달성하기 위해 Row_Number 함수를 DISTINCT 키워드와 함께 활용할 수 있습니다.

제공된 예에서 사용자는 행 번호와 함께 고유한 값을 표시하기 위해 DISTINCT를 Row_Number와 결합하려고 시도했습니다.

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

그러나 이 쿼리는 다음 쿼리와 유사한 고유한 값만 산출했습니다.

SELECT distinct id FROM table WHERE fid = 64

이 문제를 해결하려면 문제에서는 Row_Number 대신 DENSE_RANK 함수를 사용할 수 있습니다. DENSE_RANK는 데이터의 간격에 관계없이 연속된 행 번호를 고유 값에 할당합니다.

수정된 쿼리는 다음과 같습니다.

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

이 쿼리는 원하는 결과, 즉 고유 값 목록을 제공합니다. 의도한 대로 해당 행 번호를 사용하세요.

위 내용은 SQL에서 고유한 값에 행 번호를 할당하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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