IT/SQL 테스트

[SELECT] 대장균의 크기에 따라 분류하기 2 (MySQL)

자연산 금붕어 2025. 2. 5. 21:07

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로 별칭 붙임
반응형