https://school.programmers.co.kr/learn/courses/30/lessons/301649
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
- 문제 :
대장균 개체의 크기를 내름차순으로 정렬했을 때 상위 0% ~ 25% 를 'CRITICAL', 26% ~ 50% 를 'HIGH', 51% ~ 75% 를 'MEDIUM', 76% ~ 100% 를 'LOW' 라고 분류합니다. 대장균 개체의 ID(ID) 와 분류된 이름(COLONY_NAME)을 출력하는 SQL 문을 작성해주세요. 이때 결과는 개체의 ID 에 대해 오름차순 정렬해주세요 . 단, 총 데이터의 수는 4의 배수이며 같은 사이즈의 대장균 개체가 서로 다른 이름으로 분류되는 경우는 없습니다.
- 풀이 :
-- ECOLI_DATA : ID, PARENT_ID, SIZE_OF_COLONY, DIFFERENTIATION_DATE, GENOTYPE
SELECT ID,
CASE
WHEN SizeRank = 1 THEN 'CRITICAL'
WHEN SizeRank = 2 THEN 'HIGH'
WHEN SizeRank = 3 THEN 'MEDIUM'
WHEN SizeRank = 4 THEN 'LOW'
END AS COLONY_NAME
FROM
(
SELECT
ID,
SIZE_OF_COLONY,
NTILE(4) OVER (ORDER BY SIZE_OF_COLONY DESC) AS SizeRank
FROM
ECOLI_DATA
) as RankedColony
ORDER BY ID;
- CASE - END 문으로 COLONY_NAME 결정
- FROM절에 NTILE(4)랑 OVER 사용
- NTILE: 주어진 데이터 집합을 n개의 균등한 그룹으로 나눔
- OVER: 윈도우 함수가 적용될 범위 지정 -> 특정 행 집합에 대해 계산을 수행
- NTILE(4) OVER ( ORDER BY SIZE_OF_COLONY DESC) AS SizeRank 분석
- 역순 정렬된 SIZE_OF_COLONY절을 윈도우 함수 적용될 범위로 지정
- NTILE(4)로 n개의 균등한 그룹으로 나눔
- SizeRank로 별칭 붙임
반응형
'IT > SQL 테스트' 카테고리의 다른 글
[SUM, MAX, MIN] 가격이 제일 비싼 식품의 정보 출력하기 (0) | 2025.02.05 |
---|---|
[SELECT] 특정 세대의 대장균 찾기 (MySQL) (0) | 2025.02.05 |
[SELECT] 부모 형질을 모두 가지는 대장균 찾기 (MySQL) (4) | 2025.02.05 |
[SELECT] 특정 형질을 가지는 대장균 찾기 (MySQL) (0) | 2025.02.05 |
[SELECT] 대장균의 크기에 따라 분류하기 1 (MySQL) (0) | 2025.02.05 |