일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- SQLD
- 기초통계
- streamlit
- 머신러닝
- GA4
- 전처리
- 태블로
- 프로젝트
- data analyst
- da
- If
- cross join
- Chat GPT
- 팀프로젝트
- jd
- 군집화
- 기초프로젝트
- 프롬프트 엔지니어링
- 데이터분석
- pandas
- Python
- SQL
- 서브쿼리
- 히트맵
- 시각화
- 데이터 분석
- 최종 프로젝트
- lambda
- 크롤링
- 클러스터링
Archives
- Today
- Total
세조목
SQL 정리(프로그래머스 - '우유와 요거트가 담긴 장바구니')(24.01.22) 본문
https://school.programmers.co.kr/learn/courses/30/lessons/62284
SELECT DISTINCT CP1.CART_ID
FROM CART_PRODUCTS CP1 CROSS JOIN CART_PRODUCTS CP2
WHERE CP1.CART_ID = CP2.CART_ID AND CP1.NAME = 'MILK' AND CP2.NAME = 'YOGURT'
ORDER BY CP1.CART_ID
우유와 요거트를 동시에 구입한 장바구니('CART_ID')를 구해야한다.
하나의 컬럼에 하나의 속성값만 들어가있기때문에 WHERE절에서
LIKE를 쓰거나 등호(=)를 쓸수도 없다.
그렇다면 CART_PRODUCTS테이블을 CROSS JOIN하여 모든 경우의 수를 만들고
거기서 하나의 장바구니에 MILK와 YOGURT가 모두 들어있는
장바구니를 소팅하면 되지 않을까?
CART_PRODUCTS 테이블을 CROSS JOIN하면 아래 이미지에서 확인할 수 있는것처럼
모든 경우의 수를 구할 수 있다.
우측 CART_ID가 83인 경우에 모든 CART_ID의 모든 NAME이 JOIN되는 것을 확인할 수 있습니다.
여기서
WHERE CP1.CART_ID = CP2.CART_ID AND CP1.NAME = 'MILK' AND CP2.NAME = 'YOGURT'
CP1과 CP2의 CART_ID가 같고,
CP1의 NAME은 MILK,
CP2의 NAME은 YOGURT
인 경우를 소팅해주면
결과값인
이 출력되는 것을 확인할 수 있다.
'데이터 분석 공부 > SQL' 카테고리의 다른 글
SQL 정리(Join의 기준)(24.02.01) (0) | 2024.02.01 |
---|---|
SQL 정리(프로그래머스 - '주문량이 많은 아이스크림들 조회하기')(24.01.22) (0) | 2024.01.22 |
SQL 정리(하나의 쿼리로 요구하는 모든 값들을 출력할 수 없을때 - WITH, VIEW, IF)(24.01.17) (0) | 2024.01.17 |
SQL 정리(서버 연결)(24.01.12) (0) | 2024.01.12 |
SQL 정리(여러 column의 값 한번에 바꾸기)(24.01.12) (0) | 2024.01.12 |