home강의 홈으로
Section 1. SELECT 기초 - 원하는 정보 찾기
Lesson 5. 조건에 따라 그룹으로 묶기

🕹️ 실습 링크 바로가기

위의 사이트에서 실습이 안 될 시 👉 클릭해주세요!



1-3 복습 - 💡 그룹 함수

NULL값은 집계하지 않습니다.

함수 설명
MAX 가장 큰 값
MIN 가장 작은 값
COUNT 갯수 (NULL값 제외)
SUM 총합
AVG 평균 값




1. GROUP BY - 조건에 따라 집계된 값을 가져옵니다.

SELECT Country FROM Customers GROUP BY Country; SELECT CategoryID FROM Products GROUP BY CategoryID;

💡 여러 컬럼을 기준으로 그룹화할 수도 있습니다.

SELECT Country, City, CONCAT_WS(', ', City, Country) FROM Customers GROUP BY Country, City;



📚 그룹 함수 활용하기

SELECT COUNT(*), OrderDate FROM Orders GROUP BY OrderDate; SELECT ProductID, SUM(Quantity) AS QuantitySum FROM OrderDetails GROUP BY ProductID ORDER BY QuantitySum DESC; SELECT CategoryID, MAX(Price) AS MaxPrice, MIN(Price) AS MinPrice, TRUNCATE((MAX(Price) + MIN(Price)) / 2, 2) AS MedianPrice, TRUNCATE(AVG(Price), 2) AS AveragePrice FROM Products GROUP BY CategoryID; SELECT CONCAT_WS(', ', City, Country) AS Location, COUNT(CustomerID) FROM Customers GROUP BY Country, City;


💡 WITH ROLLUP - 전체의 집계값

SELECT Country, COUNT(*) FROM Suppliers GROUP BY Country WITH ROLLUP;
  • 위의 각 집계함수 쿼리 끝에 WITH ROLLUP 을 추가해보세요.
  • ⚠️ ORDER BY 와는 함께 사용될 수 없습니다.




HAVING - 그룹화된 데이터 걸러내기

SELECT Country, COUNT(*) AS Count FROM Suppliers GROUP BY Country HAVING Count >= 3;

💡 WHERE는 그룹하기 전 데이터, HAVING은 그룹 후 집계에 사용합니다.

SELECT COUNT(*) AS Count, OrderDate FROM Orders WHERE OrderDate > DATE('1996-12-31') GROUP BY OrderDate HAVING Count > 2; SELECT CategoryID, MAX(Price) AS MaxPrice, MIN(Price) AS MinPrice, TRUNCATE((MAX(Price) + MIN(Price)) / 2, 2) AS MedianPrice, TRUNCATE(AVG(Price), 2) AS AveragePrice FROM Products WHERE CategoryID > 2 GROUP BY CategoryID HAVING AveragePrice BETWEEN 20 AND 30 AND MedianPrice < 40;




2. DISTINCT - 중복된 값들을 제거합니다.

  • GROUP BY 와 달리 집계함수가 사용되지 않습니다.
  • GROUP BY 와 달리 정렬하지 않으므로 더 빠릅니다.

SELECT DISTINCT CategoryID FROM Products; -- 위의 GROUP BY를 사용한 쿼리와 결과 비교 SELECT COUNT DISTINCT CategoryID FROM Products; -- 오류 발생
SELECT DISTINCT Country FROM Customers ORDER BY Country; SELECT DISTINCT Country, City FROM Customers ORDER BY Country, City;

💡 GROUP BYDISTINCT 함께 활용하기

SELECT Country, COUNT(DISTINCT CITY) FROM Customers GROUP BY Country;

🤔얄코에게 질문하기질문은 반.드.시 이리로 보내주세요! ( 강의사이트 질문기능 ✖ )

강의에서 이해가 안 되거나 실습상 문제가 있는 부분,
설명이 잘못되었거나 미흡한 부분을 메일로 알려주세요!

답변드린 뒤 필요할 경우 본 페이지에
관련 내용을 추가/수정하도록 하겠습니다.

이메일 주소
yalco@yalco.kr
메일 제목 (반드시 아래 제목을 붙여넣어주세요!)
[질문] MySQL 1-5

🛑질문 전 필독!!

  • 구글링을 먼저 해 주세요. 들어오는 질문의 절반 이상은 구글에 검색해 보면 1분 이내로 답을 찾을 수 있는 내용들입니다.
  • 오류 메시지가 있을 경우 이를 구글에 복붙해서 검색해보면 대부분 짧은 시간 내 해결방법을 찾을 수 있습니다.
  • 강의 페이지에 추가사항 등 놓친 부분이 없는지 확인해주세요. 자주 들어오는 질문은 페이지에 추가사항으로 업데이트됩니다.
  • "유료파트의 강의페이지는 어디 있나요?" - 각 영상의 시작부분 검은 화면마다 해당 챕터의 강의페이지 링크가 있습니다.
  • 질문을 보내주실 때는 문제가 어떻게 발생했고 어떤 상황인지 등을 구체적으로 적어주세요. 스크린샷을 첨부해주시면 더욱 좋습니다.
🌏 Why not change the world?