항해99 온보딩 스터디[SQL 학습] 16일차

Hohomi·2023년 3월 24일
0
post-thumbnail

스터디 16일차 : SQL 문제 풀이

16일차의 문제는 어제보다 조금 더 레벨업 된 것들이었다. 구글링 하면서 강의에서 배우지 않은 sql 내장 함수들도 사용해보았는데, 사용법은 그리 까다롭지 않았다.


⚙️ INNER JOIN 사용

과일로 만든 아이스크림 고르기
문제 : 상반기 아이스크림 총주문량이 3,000보다 높으면서 아이스크림의 주 성분이 과일인 아이스크림의 맛을 총주문량이 큰 순서대로 조회하는 SQL 문을 작성해주세요.

SELECT F.FLAVOR FROM FIRST_HALF F
INNER JOIN ICECREAM_INFO I ON I.FLAVOR = F.FLAVOR
WHERE F.TOTAL_ORDER >= 3000 AND I.INGREDIENT_TYPE = 'fruit_based'
  • join 하는 건 어렵지 않았는데, join 후에 조인한 테이블의 별칭(여기서는 F와 I)을 모든 컬럼 앞에 붙여주어야 한다는 걸 자꾸 까먹는다.
  • 문제에서 "ICECREAM_INFO의 기본 키는 FLAVOR이고, ICECREAM_INFO테이블의 FLAVOR는 FIRST_HALF 테이블의 FLAVOR의 외래 키"라는 말이 나왔는데, 바로 이 기본키와 외래키의 관계가 join을 가능하게 한다.
  • where 절에서 추가 조건 걸고 싶을 때 and 를 사용한다. (or도 사용가능)

⚙️ 날짜와 관련된 DATE_FORMAT, DATEDIFF

자동차 대여 기록에서 장기/단기 대여 구분하기
문제 : CAR_RENTAL_COMPANY_RENTAL_HISTORY 테이블에서 대여 시작일이 2022년 9월에 속하는 대여 기록에 대해서 대여 기간이 30일 이상이면 '장기 대여' 그렇지 않으면 '단기 대여' 로 표시하는 컬럼(컬럼명: RENT_TYPE)을 추가하여 대여기록을 출력하는 SQL문을 작성해주세요. 결과는 대여 기록 ID를 기준으로 내림차순 정렬해주세요.

SELECT 
       HISTORY_ID, 
       CAR_ID, 
       DATE_FORMAT(START_DATE, '%Y-%m-%d') AS START_DATE, 
       DATE_FORMAT(END_DATE, '%Y-%m-%d') AS END_DATE,
    IF(DATEDIFF(END_DATE, START_DATE) >= 29, '장기 대여', '단기 대여') AS RENT_TYPE 
  FROM CAR_RENTAL_COMPANY_RENTAL_HISTORY 
 WHERE DATE_FORMAT(START_DATE, '%Y-%m') = '2022-09'
 ORDER BY HISTORY_ID DESC
  • DATE_FORMAT(날짜, 형식) : 날짜를 지정한 형식으로 출력하는 함수
    • '%Y-%m-%d' 로 입력하면 '2023-09-30'이 출력된다.
  • DATEDIFF : 날짜, 시간 차이를 구하는 함수
    SELECT DATEDIFF('구분자','Start_Date','End_Date')



참고자료

DATE_FORMAT 날짜 형식 설정
JOIN
WHERE절 다중 조건

profile
게발로 개발하기

0개의 댓글