티스토리 뷰
프로그래머스 SQL 고득점 kit 12일차( GROUP BY 1문제, JOIN 7문제 )
1. ON에 AND 사용 가능
- 여러 조건을 동시에 만족해야 하는 경우 사용(필요하지 않은 데이터 배제)
- ON에 있는 경우, 조건이 두 테이블의 연결 기준으로 작용, WHERE에 있는 경우 모든 데이터를 연결한 후 필터링
2. 특정기간동안 대여 가능한 자동차들의 대여 비용 구하기
- 2022-11-01에서 2022-11-30 동안 대여 가능한 차량 조회
- 1번의 경우 중복이 발생할 수 있다. 합집합이 아닌 교집합인 2번 방법을 사용
# 1번
(START_DATE BETWEEN '2022-01-01' AND '2022-11-30')
OR (END_DATE BETWEEN '2022-01-01' AND '2022-11-30')
# 2번
(START_DATE <='2022-11-30' AND END_DATE >='2022-11-01')
SELECT C.CAR_ID, C.CAR_TYPE, ROUND(C.DAILY_FEE*(1-P.DISCOUNT_RATE/100)*30,0) AS FEE
FROM CAR_RENTAL_COMPANY_CAR C
JOIN CAR_RENTAL_COMPANY_DISCOUNT_PLAN P
ON C.CAR_TYPE = P.CAR_TYPE
AND P.DURATION_TYPE = '30일 이상'
AND C.CAR_TYPE IN ('세단', 'SUV')
LEFT JOIN CAR_RENTAL_COMPANY_RENTAL_HISTORY H
ON C.CAR_ID = H.CAR_ID
AND(START_DATE <='2022-11-30' AND END_DATE >='2022-11-01')
WHERE (START_DATE IS NULL AND END_DATE IS NULL)
AND ROUND(C.DAILY_FEE*(1-P.DISCOUNT_RATE/100)*30,0) >= 500000
AND ROUND(C.DAILY_FEE*(1-P.DISCOUNT_RATE/100)*30,0) < 2000000
ORDER BY FEE DESC, C.CAR_TYPE, C.CAR_ID DESC
3. EXISTS에서 WHERE 는 연결기준(ON)과 비슷한 역할을 한다.
SELECT *
FROM employees E
WHERE EXISTS (
SELECT 1
FROM attendance A
WHERE E.employee_id = A.employee_id
AND A.date >= '2022-01-01'
);
반응형
'AI > SQL' 카테고리의 다른 글
[SQL] 문자열 삽입(INSERT) (1) | 2024.12.15 |
---|---|
[SQL] 날짜 계산(덧셈, 뺄셈), 분기 추출(QUARTER), 문자열 인덱싱(LEFT, SUBSTRING) (0) | 2024.12.14 |
[SQL] JOIN 조건(ON)과 비트연산 (0) | 2024.12.12 |
[SQL] CONCAT으로 특정 포맷 지정 후 정렬 시 주의 (0) | 2024.12.11 |
[SQL] 0부터 23까지 숫자 만들기 (WITH RECURSIVE), 나누기 몫(DIV), IFNULL과 COALESCE, 경계값 포함 BETWEEN (0) | 2024.12.10 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- opic
- 티스토리챌린지
- 다이어트
- 줄넘기
- ChatGPT
- SQL
- 아침운동
- 기초
- C언어
- 영어회화
- Ai
- llm
- 스크랩
- 오픽
- 오블완
- 아침
- 운동
- IH
- Python
- 고득점 Kit
- 뉴스
- 경제
- 프로그래머스
- 실기
- 루틴
- 미라클모닝
- 갓생
- 30분
- 습관
- 빅데이터 분석기사
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
글 보관함