티스토리 뷰
프로그래머스 SQL 고득점 kit 6일차( SELECT level4-1문제, level5-1문제, SELECT 문제 풀이 끝!)
1.UNION
1) UNION ALL
- 중복된 행을 포함하여 반환 (모든 행 포함), 중복제거 및 정렬을 하지 않아 UNION보다 성능이 좋다
SELECT id, name FROM table1
UNION ALL
SELECT id, name FROM table2;
2) UNION
- 중복된 행을 제거한 결과를 반환한다
SELECT id, name FROM table1
UNION
SELECT id, name FROM table2;
3) 문제풀이
SELECT *
FROM (
SELECT DATE_FORMAT(SALES_DATE,'%Y-%m-%d') AS SALES_DATE, PRODUCT_ID, USER_ID, SALES_AMOUNT
FROM ONLINE_SALE
UNION ALL
SELECT SALES_DATE, PRODUCT_ID, NULL AS USER_ID, SALES_AMOUNT
FROM OFFLINE_SALE
) AS A
WHERE (SALES_DATE >= '2022-03-01') AND (SALES_DATE < '2022-04-01')
ORDER BY SALES_DATE, PRODUCT_ID, USER_ID
2. WITH RECURSEIVE
- 자기 자신을 반복적으로 호출하여 계층적 데이터나 반복 잡업을 처리하는 기증
- 트리구조나 그래프 탐색, 재귀적 계산 등을 수행할 때 사용
- 재귀의 시작점이 되는 앵커(Anchor)쿼리와 자기 자신을 호출하는 재귀(Recursive)쿼리 두 부분으로 나뉜다.
(예시) employees 테이블
ID | NAME | MANAGER_ID |
1 | Alice | NULL |
2 | Bob | 1 |
3 | Charlie | 1 |
4 | Diana | 2 |
5 | Eva | 2 |
WITH RECURSIVE employee_hierarchy AS (
-- 앵커 쿼리: 최상위 관리자
SELECT ID, Name, Manager_ID, 1 AS Level
FROM employees
WHERE Manager_ID IS NULL
UNION ALL
-- 재귀 쿼리: 하위 직원 탐색
SELECT e.ID, e.Name, e.Manager_ID, h.Level + 1
FROM employees e
INNER JOIN employee_hierarchy h
ON e.Manager_ID = h.ID
)
SELECT *
FROM employee_hierarchy;
(결과)
ID | NAME | MANAGER_ID | LEVEL |
1 | Alice | NULL | 1 |
2 | Bob | 1 | 2 |
3 | Charlie | 1 | 2 |
4 | Diana | 2 | 3 |
5 | Eva | 2 | 3 |
반응형
'AI > SQL' 카테고리의 다른 글
[SQL] 반올림, 올림, 내림(Round, Ceil, Floor), 천단위 구분(Format) (1) | 2024.12.09 |
---|---|
[SQL] 윈도우 함수 (RANK, PARTITION BY), 문자열(FORMAT, CONCAT) (1) | 2024.12.08 |
[SQL] 조건문 CASE, 윈도우 함수 PERCENT RANK(백분율 순위), NTILE (0) | 2024.12.06 |
[SQL] WITH, IN과 EXISTS차이 (0) | 2024.12.05 |
[SQL] 서브쿼리와 JOIN (0) | 2024.12.04 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- Python
- 뉴스
- 빅데이터 분석기사
- llm
- 운동
- 오블완
- 기초
- 아침운동
- C언어
- 실기
- ChatGPT
- 30분
- 아침
- 고득점 Kit
- 줄넘기
- 스크랩
- 오픽
- 습관
- opic
- Ai
- SQL
- 다이어트
- 영어회화
- 경제
- 갓생
- 티스토리챌린지
- IH
- 프로그래머스
- 루틴
- 미라클모닝
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함