티스토리 뷰

프로그래머스 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

 

반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/12   »
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
글 보관함