티스토리 뷰

AI/SQL

[SQL] JOIN 조건(ON)과 비트연산

brave_sol 2024. 12. 12. 12:29
프로그래머스 SQL 고득점 kit 11일차( GROUP BY 1문제)

 

1. JOIN 시 ON 조건에 비트연산(&)을 활용하면 특정 조건에서 하나라도 포함하는 조건의 열을 가져올 수 있다.

SELECT D.EMAIL, BIN(D.SKILL_CODE) AS SKILL_CODE, C.NAME,  BIN(C.CODE) AS CODE
FROM DEVELOPERS D
LEFT JOIN SKILLCODES C
ON (D.SKILL_CODE & C.CODE) != 0

- 출력 결과

EMAIL SKILL_CODE NAME CODE
JERAMI_EDWARDS@GREPP.CO 110010000 Python 100000000
JERAMI_EDWARDS@GREPP.CO 110010000 Java 10000000
JERAMI_EDWARDS@GREPP.CO 110010000 JavaScript 10000

 

2. ON 조건에 &외에도 IN이나 EXISTS도 쓸 수 있다

조건 & IN EXISTS
속도 매우 빠름 작을 때 빠름 대규모 데이터에서 효율적
복잡도 낮음 중간 중간
상황 비트 연산이 필요한 경우 서브쿼리 결과가 작을 때 서브쿼리 결과가 클 때

 

3. 프로그래머스 언어별 개발자 분류하기 풀이

- HAVING은 GROUP BY 이후 SELECT에서 정의한 별칭을 사용할 수 있다

SELECT 
    CASE 
        WHEN SUM(CASE WHEN C.NAME="Python" THEN 1 ELSE 0 END) > 0 
        AND SUM(CASE WHEN C.CATEGORY = "Front End" THEN 1 ELSE 0 END) > 0
        THEN "A"
        WHEN SUM(CASE WHEN C.NAME = "C#" THEN 1 ELSE 0 END) > 0 THEN "B"
        WHEN SUM(CASE WHEN C.CATEGORY = "Front End" THEN 1 ELSE 0 END) > 0 THEN "C"
        ELSE NULL
    END AS GRADE,
    D.ID,
    D.EMAIL
FROM DEVELOPERS D
LEFT JOIN SKILLCODES C
ON (D.SKILL_CODE & C.CODE) != 0 
GROUP BY D.ID, D.EMAIL
HAVING GRADE IS NOT NULL
ORDER BY GRADE, D.ID
반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
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
글 보관함