대장균 개체의 크기를 내름차순으로 정렬했을 때 상위 0% ~ 25% 를 'CRITICAL', 26% ~ 50% 를 'HIGH', 51% ~ 75% 를 'MEDIUM', 76% ~ 100% 를 'LOW' 라고 분류합니다. 대장균 개체의 ID(ID) 와 분류된 이름(COLONY_NAME)을 출력하는 SQL 문을 작성해주세요. 이때 결과는 개체의 ID 에 대해 오름차순 정렬해주세요 . 단, 총 데이터의 수는 4의 배수이며 같은 사이즈의 대장균 개체가 서로 다른 이름으로 분류되는 경우는 없습니다.
https://school.programmers.co.kr/learn/courses/30/lessons/301649
-- 크기를 내름차순으로 정렬 후 순위로 분류
WITH size_rank AS(
SELECT
ID,
NTILE(4) OVER (ORDER BY SIZE_OF_COLONY DESC) '등급'
FROM ECOLI_DATA
ORDER BY ID
)
SELECT
ID,
CASE
WHEN 등급 = 1 THEN 'CRITICAL'
WHEN 등급 = 2 THEN 'HIGH'
WHEN 등급 = 3 THEN 'MEDIUM'
ELSE 'LOW'
END 'COLONY_NAME'
FROM size_rank
각 분기(QUARTER)별 분화된 대장균의 개체의 총 수(ECOLI_COUNT)를 출력하는 SQL 문을 작성해주세요. 이때 각 분기에는 'Q' 를 붙이고 분기에 대해 오름차순으로 정렬해주세요. 대장균 개체가 분화되지 않은 분기는 없습니다.
https://school.programmers.co.kr/learn/courses/30/lessons/299308
-- 분기 설정
WITH qua AS(
SELECT
CASE
WHEN MONTH(DIFFERENTIATION_DATE) BETWEEN 1 AND 3 THEN '1Q'
WHEN MONTH(DIFFERENTIATION_DATE) BETWEEN 3 AND 6 THEN '2Q'
WHEN MONTH(DIFFERENTIATION_DATE) BETWEEN 6 AND 9 THEN '3Q'
ELSE '4Q'
END 'QUARTER'
FROM ECOLI_DATA
)
SELECT *, COUNT(QUARTER) ECOLI_COUNT
FROM qua
GROUP BY QUARTER
ORDER BY QUARTER
SELECT
CONCAT(QUARTER(DIFFERENTIATION_DATE), 'Q') QUARTER,
COUNT(*) ECOLI_COUNT
FROM ECOLI_DATA
GROUP BY QUARTER
ORDER BY QUARTER