https://school.programmers.co.kr/learn/courses/30/lessons/132202
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
문제 분석
난이도 : level 2
문제 요구사항
APPOINTMENT 테이블에서 2022년 5월에 예약한 환자 수를 진료과코드 별로 조회하는 SQL문을 작성해주세요. 이때, 컬럼명은 '진료과 코드', '5월예약건수'로 지정해주시고 결과는 진료과별 예약한 환자 수를 기준으로 오름차순 정렬하고, 예약한 환자 수가 같다면 진료과 코드를 기준으로 오름차순 정렬해주세요.
문제 풀이
1. DATE_FORMAT을 사용하는 방법
- 2022-05월에 예약한 환자수를 확인해야하기 때문에 DATE_FORMAT과 WHERE을 사용해서 날짜가 2022-05인 데이터들만 추출한다.
- GROUP BY를 사용해 진료과 코드별로 묶어준다.
- COUNT를 사용해 진료과별로 예약건수를 집계한다.
- ORDER BY로 정렬순서를 결정한다.
SELECT MCDP_CD AS '진료과 코드', COUNT(*) AS 5월예약건수
FROM APPOINTMENT
WHERE DATE_FORMAT(APNT_YMD, '%Y-%m') = '2022-05'
GROUP BY MCDP_CD
ORDER BY 5월예약건수 ASC, MCDP_CD
2. LIKE를 사용하는 방법
날짜가 2022-05인 데이터들만 추출할 때, DATE_FORMAT인 아닌 LIKE를 사용해서 APNT_YMD에 '2022-05'가 들어있는 행만 추출한다.
SELECT MCDP_CD AS '진료과 코드', COUNT(*) AS 5월예약건수
FROM APPOINTMENT
WHERE APNT_YMD LIKE '2022-05%'
GROUP BY MCDP_CD
ORDER BY 5월예약건수 ASC, MCDP_CD'하루 30분 SQL 공부하기' 카테고리의 다른 글
| [MySQL] 프로그래머스 성분으로 구분한 아이스크림 총 주문량 (1) | 2024.10.15 |
|---|---|
| [MySQL] 프로그래머스 자동차 종류 별 특정 옵션이 포함된 자동차 수 구하기 (0) | 2024.10.15 |
| [SQL 코테준비] 가격이 제일 비싼 식품의 정보 출력하기, 잡은 물고기 중 가장 큰 물고기의 길이 구하기 프로그래머스 (0) | 2024.10.10 |
| [MySQL] 프로그래머스 코딩테스트 문제 풀이 SELECT 과일로 만든 아이스크림 고르기, 조건에 부합하는 중고거래 댓글 조회하기 (0) | 2024.10.08 |
| [SQL/DFL] SELECT문의 WHERE절과 논리, 비교, SQL 연산자 (2) | 2024.10.02 |