Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- SQL
- DBMS
- IntelliJ
- java
- 11월순위
- 자바
- analytics4
- spring
- 오블완
- 티스토리챌린지
- 애널리틱스4
- JPA
- oracle
- macvlan
- mssql
- gtihub
- ANTIFRAGILE
- codeium
- Python
- API
- docker
- mysql
- 명령어
- 르세라핌
- PostgreSQL
- git pat
- pat발급
- 데이터내보내기
- db종류
Archives
- Today
- Total
hanker
SQL - 데이터 순위 부여 방법 (MySQL, MSSQL, Oracle, PostgreSQL) 본문
반응형
SQL에서 데이터(쿼리결과)의 순위를 부여하는 방법에 대해서 알아보자.
공통 (MySQL8.0 이상 지원 / MSSQL / Oracle / PostgreSQL)
윈도우 함수를 이용
1. RANK : 동일한 값일 경우 동일 순위를 부여하고 다음 순위는 건너뛴다.
SELECT
employee_name,
department_id,
salary,
RANK() OVER (PARTITION BY department_id ORDER BY salary DESC) AS rank_in_department
FROM employees;
* 각 부서별로 직원들의 급여 순위를 반환
2. DENSE_RANK : 동일 순위를 부여하지만, 다음 순위를 건너뛰지 않음
SELECT
employee_name,
department_id,
salary,
DENSE_RANK() OVER (PARTITION BY department_id ORDER BY salary DESC) AS rank_in_department
FROM employees;
* 각 부서별로 직원들의 급여 순위를 반환 (RANK와 달리 중복된 순위를 처리하면서도 간격을 건너뛰지 않음)
3. ROW_NUMBER: 그룹 내에서 고유한 순번을 부여
SELECT
employee_name,
department_id,
salary,
ROW_NUMBER() OVER (PARTITION BY department_id ORDER BY salary DESC) AS row_number_in_department
FROM employees;
* 각 부서별로 급여를 정렬 후 각 행에 고유한 순번을 부여
MSSQL
- NTILE(n): 데이터셋을 n개의 그룹으로 나눈다.
SELECT name, sales,
NTILE(4) OVER (ORDER BY sales DESC) AS quartile
FROM sales_data;
1. 데이터 집합을 4개의 그룹으로 나누며, 각 그룹 번호가 각 행에 부여
2. 데이터는 ORDER BY 절에 따라 정렬된 후 그룹으로 나뉨
3. 그룹의 크기가 정확히 나누어떨어지지 않는 경우, 앞쪽 그룹에 한 행씩 더 많은 데이터를 포함
예를 들어, 데이터가 10개이고 NTILE(3)을 사용할 경우
- 첫 번째 그룹: 4개 행
- 두 번째 그룹: 3개 행
- 세 번째 그룹: 3개 행
Oracle
Oracle에서는 ROWNUM을 사용할 수 있지만, 이는 정렬이 완료된 후 순위를 부여하지 않기 때문에 윈도우 함수를 사용하는 것이 더 적합하다.
반응형