SQL Test

박무연·2023년 3월 14일
0

🔵SQL

목록 보기
13/15
post-thumbnail

- 문제

REST_INFO 테이블에서 음식종류별로 즐겨찾기수가 가장 많은 식당의 음식 종류, ID, 식당 이름, 즐겨찾기수를 조회하는 SQL문을 작성해주세요. 이때 결과는 음식 종류를 기준으로 내림차순 정렬해주세요.

- 풀이

SELECT r.food_type, r.rest_id, r.rest_name, r.favorites
FROM REST_INFO r, (SELECT food_type, MAX(favorites) maxv FROM REST_INFO GROUP BY food_type) tmp
WHERE r.food_type = tmp.food_type 
  AND r.favorites = tmp.maxv
order by r.food_type desc
  • max(favorites) 안돼는 이유 : max(favorites) 에 해당하는 FOOD_TYPE, REST_ID, REST_NAME이 아니다. 묶어줄 필요가 있다.
  • 서브쿼리를 이요해 type 과 max를 묶어줄 필요가 있다.
  • with ~ as

e.g)

WITH CTE AS (
   SELECT FOOD_TYPE, MAX(FAVORITES) AS MAX_FAVORITES
   FROM REST_INFO
   GROUP BY FOOD_TYPE
)
SELECT
     R1.FOOD_TYPE,
     R1.REST_ID,
     R1.REST_NAME,
     R1.FAVORITES
 FROM 
     REST_INFO R1,
     CTE R2
 WHERE R1.FOOD_TYPE = R2.FOOD_TYPE AND R1.FAVORITES = R2.MAX_FAVORITES
 GROUP BY 1 
 ORDER BY 1 DESC

출처 : programmers > GROUP BY > 즐겨찾기가 가장 많은 식당 정보 출력하기

- 문제

APPOINTMENT 테이블에서 2022년 5월에 예약한 환자 수를 진료과코드 별로 조회하는 SQL문을 작성해주세요. 이때, 컬럼명은 '진료과 코드', '5월예약건수'로 지정해주시고 결과는 진료과별 예약한 환자 수를 기준으로 오름차순 정렬하고, 예약한 환자 수가 같다면 진료과 코드를 기준으로 오름차순 정렬해주세요.

- 풀이

select MCDP_CD 진료과코드 , count(APNT_YMD) 5월예약건수
from APPOINTMENT 
where month(APNT_YMD) = 5
group by MCDP_CD
order by count(APNT_YMD), MCDP_CD
  • date_format을 사용하지 않고 month를 사요하면 달을 출력할 수 있따.
profile
Easy day!

0개의 댓글