티스토리 뷰
프로그래머스 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
- 출력 결과
| 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반응형
'AI > SQL' 카테고리의 다른 글
| [SQL] 날짜 계산(덧셈, 뺄셈), 분기 추출(QUARTER), 문자열 인덱싱(LEFT, SUBSTRING) (0) | 2024.12.14 |
|---|---|
| [SQL] JOIN 조건(ON)과 AND, EXISTS의 WHERE (0) | 2024.12.13 |
| [SQL] CONCAT으로 특정 포맷 지정 후 정렬 시 주의 (0) | 2024.12.11 |
| [SQL] 0부터 23까지 숫자 만들기 (WITH RECURSIVE), 나누기 몫(DIV), IFNULL과 COALESCE, 경계값 포함 BETWEEN (0) | 2024.12.10 |
| [SQL] 반올림, 올림, 내림(Round, Ceil, Floor), 천단위 구분(Format) (2) | 2024.12.09 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- opic
- 프로그래머스
- ChatGPT
- 아침운동
- SQL
- 스크랩
- 미라클모닝
- llm
- 영어회화
- 줄넘기
- 기초
- Ai
- 아침
- 갓생
- 운동
- C언어
- 30분
- 실기
- 뉴스
- 경제
- 습관
- 다이어트
- 고득점 Kit
- 오블완
- IH
- Python
- 티스토리챌린지
- 빅데이터 분석기사
- 오픽
- 루틴
| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 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 |
글 보관함