home강의 홈으로
Section 2. SELECT 더 깊이 파보기
Lesson 2. JOIN - 여러 테이블 조립하기

🕹️ 실습 링크 바로가기

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


1. JOIN(INNER JOIN) - 내부 조인

  • 양쪽 모두에 값이 있는 행(NOT NULL) 반환
  • 'INNER '는 선택사항

SELECT * FROM Categories C JOIN Products P ON C.CategoryID = P.CategoryID;
SELECT C.CategoryID, C.CategoryName, P.ProductName FROM Categories C JOIN Products P ON C.CategoryID = P.CategoryID; -- ambiguous 주의!
SELECT CONCAT( P.ProductName, ' by ', S.SupplierName ) AS Product, S.Phone, P.Price FROM Products P JOIN Suppliers S ON P.SupplierID = S.SupplierID WHERE Price > 50 ORDER BY ProductName;



💡 여러 테이블을 JOIN할 수 있습니다.

SELECT C.CategoryID, C.CategoryName, P.ProductName, O.OrderDate, D.Quantity FROM Categories C JOIN Products P ON C.CategoryID = P.CategoryID JOIN OrderDetails D ON P.ProductID = D.ProductID JOIN Orders O ON O.OrderID = D.OrderID;

💡 JOIN한 테이블 GROUP하기

SELECT C.CategoryName, MIN(O.OrderDate) AS FirstOrder, MAX(O.OrderDate) AS LastOrder, SUM(D.Quantity) AS TotalQuantity FROM Categories C JOIN Products P ON C.CategoryID = P.CategoryID JOIN OrderDetails D ON P.ProductID = D.ProductID JOIN Orders O ON O.OrderID = D.OrderID GROUP BY C.CategoryID; SELECT C.CategoryName, P.ProductName, MIN(O.OrderDate) AS FirstOrder, MAX(O.OrderDate) AS LastOrder, SUM(D.Quantity) AS TotalQuantity FROM Categories C JOIN Products P ON C.CategoryID = P.CategoryID JOIN OrderDetails D ON P.ProductID = D.ProductID JOIN Orders O ON O.OrderID = D.OrderID GROUP BY C.CategoryID, P.ProductID;



💡 SELF JOIN - 같은 테이블끼리

SELECT E1.EmployeeID, CONCAT_WS(' ', E1.FirstName, E1.LastName) AS Employee, E2.EmployeeID, CONCAT_WS(' ', E2.FirstName, E2.LastName) AS NextEmployee FROM Employees E1 JOIN Employees E2 ON E1.EmployeeID + 1 = E2.EmployeeID; -- 1번의 전, 마지막 번호의 다음은?



2. LEFT/RIGHT OUTER JOIN - 외부 조인

  • 반대쪽에 데이터가 있든 없든(NULL), 선택된 방향에 있으면 출력 - 행 수 결정
  • 'OUTER '는 선택사항

SELECT E1.EmployeeID, CONCAT_WS(' ', E1.FirstName, E1.LastName) AS Employee, E2.EmployeeID, CONCAT_WS(' ', E2.FirstName, E2.LastName) AS NextEmployee FROM Employees E1 LEFT JOIN Employees E2 ON E1.EmployeeID + 1 = E2.EmployeeID ORDER BY E1.EmployeeID; -- LEFT를 RIGHT로 바꿔서도 실행해 볼 것
SELECT C.CustomerName, S.SupplierName, C.City, C.Country FROM Customers C LEFT JOIN Suppliers S ON C.City = S.City AND C.Country = S.Country; -- LEFT를 RIGHT로 바꿔서도 실행해 볼 것 SELECT IFNULL(C.CustomerName, '-- NO CUSTOMER --'), IFNULL(S.SupplierName, '-- NO SUPPLIER --'), IFNULL(C.City, S.City), IFNULL(C.Country, S.Country) FROM Customers C LEFT JOIN Suppliers S ON C.City = S.City AND C.Country = S.Country; -- LEFT를 RIGHT로 바꿔서도 실행해 볼 것



3. CROSS JOIN - 교차 조인

  • 조건 없이 모든 조합 반환(A * B)

SELECT E1.LastName, E2.FirstName FROM Employees E1 CROSS JOIN Employees E2 ORDER BY E1.EmployeeID;

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

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

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

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

🛑질문 전 필독!!

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