집 >데이터 베이스 >MySQL 튜토리얼 >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 중국어 웹사이트의 기타 관련 기사를 참조하세요!