[MySQL] 기본 SELECT

2024. 4. 27. 14:29🧑🏻‍💻/Database

재구매가 일어난 상품과 회원 리스트 구하기

ONLINE_SALE 테이블에서 USER_ID와 PRODUCT_ID만 뽑아내는데, 
USER_ID와 PRODUCT_ID를 그룹화 시켜서 2개 이상 중복되는 경우에 SELECT 할 때
USER_ID를 오름차순으로 정렬, PRODUCT_ID를 내림차순으로 정렬 시키는 Query

SELECT USER_ID, PRODUCT_ID 
FROM ONLINE_SALE
GROUP BY USER_ID, PRODUCT_ID 
HAVING COUNT(*) > 1
ORDER BY USER_ID ASC, PRODUCT_ID DESC;

 

https://school.programmers.co.kr/learn/courses/30/lessons/131536

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

오프라인/온라인 판매 데이터 통합하기

두 데이터베이스 통합하기.

UNION ALL을 사용해서 통합한다.

SELECT DATE_FORMAT(SALES_DATE, "%Y-%m-%d") AS SALES_DATE, PRODUCT_ID, USER_ID, SALES_AMOUNT
FROM ONLINE_SALE
WHERE MONTH(SALES_DATE) = '3'

UNION ALL

SELECT DATE_FORMAT(SALES_DATE, "%Y-%m-%d") AS SALES_DATE, PRODUCT_ID, NULL AS USER_ID, SALES_AMOUNT
FROM OFFLINE_SALE
WHERE MONTH(SALES_DATE) = '3'

ORDER BY SALES_DATE ASC, PRODUCT_ID ASC ,USER_ID ASC;