home강의 홈으로
Section 2. SELECT 더 깊이 파보기
Lesson 1. 쿼리 안에 서브쿼리

🕹️ 실습 링크 바로가기

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



1. 비상관 서브쿼리


SELECT CategoryID, CategoryName, Description, (SELECT ProductName FROM Products WHERE ProductID = 1) FROM Categories;
SELECT * FROM Products WHERE Price < ( SELECT AVG(Price) FROM Products );
SELECT CategoryID, CategoryName, Description FROM Categories WHERE CategoryID = (SELECT CategoryID FROM Products WHERE ProductName = 'Chais');
SELECT CategoryID, CategoryName, Description FROM Categories WHERE CategoryID IN (SELECT CategoryID FROM Products WHERE Price > 50);



연산자 의미
~ ALL 서브쿼리의 모든 결과에 대해 ~하다
~ ANY 서브쿼리의 하나 이상의 결과에 대해 ~하다

SELECT * FROM Products WHERE Price > ALL ( SELECT Price FROM Products WHERE CategoryID = 2 );
SELECT CategoryID, CategoryName, Description FROM Categories WHERE CategoryID = ANY (SELECT CategoryID FROM Products WHERE Price > 50);



2. 상관 서브쿼리


SELECT ProductID, ProductName, ( SELECT CategoryName FROM Categories C WHERE C.CategoryID = P.CategoryID ) AS CategoryName FROM Products P;
SELECT SupplierName, Country, City, ( SELECT COUNT(*) FROM Customers C WHERE C.Country = S.Country ) AS CustomersInTheCountry, ( SELECT COUNT(*) FROM Customers C WHERE C.Country = S.Country AND C.City = S.City ) AS CustomersInTheCity FROM Suppliers S;
SELECT CategoryID, CategoryName, ( SELECT MAX(Price) FROM Products P WHERE P.CategoryID = C.CategoryID ) AS MaximumPrice, ( SELECT AVG(Price) FROM Products P WHERE P.CategoryID = C.CategoryID ) AS AveragePrice FROM Categories C;
SELECT ProductID, ProductName, CategoryID, Price -- ,(SELECT AVG(Price) FROM Products P2 -- WHERE P2.CategoryID = P1.CategoryID) FROM Products P1 WHERE Price < ( SELECT AVG(Price) FROM Products P2 WHERE P2.CategoryID = P1.CategoryID );

EXISTS / NOT EXISTS 연산자

SELECT CategoryID, CategoryName -- ,(SELECT MAX(P.Price) FROM Products P -- WHERE P.CategoryID = C.CategoryID -- ) AS MaxPrice FROM Categories C WHERE EXISTS ( SELECT * FROM Products P WHERE P.CategoryID = C.CategoryID AND P.Price > 80 );

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

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

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

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

🛑질문 전 필독!!

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