티스토리 뷰

728x90

SUBQUERY에서 IN, ALL, ANY 3가지 조건을 사용할 수 있다.

 

아래 쿼리는 서브쿼리로 사용할 구문으로 결과는 4006, 4007, 4008 3개의 값을 출력한다.

SELECT PurchaseOrderID
FROM [AdventureWorks2014].[Purchasing].[PurchaseOrderHeader]
WHERE RevisionNumber > 10

결과
4006
4007
4008

IN 연산자는 가장 흔하게 사용하는 조건으로 해당 조건과 정확히 일치하는 결과를 출력한다.

즉, 결과 값이었던 4006, 4007, 4008과 일치하는 결과를 리턴한다.

--################################
-- SUBQUERY - IN 
--################################
SELECT *
FROM [AdventureWorks2014].[Purchasing].[PurchaseOrderDetail]
WHERE PurchaseOrderID IN (
	SELECT PurchaseOrderID
	FROM [AdventureWorks2014].[Purchasing].[PurchaseOrderHeader]
	WHERE RevisionNumber > 10
)
ORDER BY PurchaseOrderID

SELECT *
FROM [AdventureWorks2014].[Purchasing].[PurchaseOrderDetail]
WHERE PurchaseOrderID IN (4006, 4007, 4008)
ORDER BY PurchaseOrderID

ALL 연산자는 서브쿼리에서 나온 결과값의 MAX값을 기준으로 조건을 계산하여 출력한다.

즉, PurchaseOrderID가 결과값이었던 4006, 4007, 4008 중 MAX인 4008보다 크거나 같은 데이터를 출력하게 된다.

--################################
-- SUBQUERY - ALL
--################################
SELECT *
FROM [AdventureWorks2014].[Purchasing].[PurchaseOrderDetail]
WHERE PurchaseOrderID >= ALL (
	SELECT PurchaseOrderID
	FROM [AdventureWorks2014].[Purchasing].[PurchaseOrderHeader]
	WHERE RevisionNumber > 10
)
ORDER BY PurchaseOrderID

SELECT *
FROM [AdventureWorks2014].[Purchasing].[PurchaseOrderDetail]
WHERE PurchaseOrderID >= (4008)
ORDER BY PurchaseOrderID

SUBQUERY - ALL 결과 -> 4008 이상 출력

마지막으로 ANY 연산자는 ALL 과 반대로 서브쿼리에서 나온 결과값의 전체를 기준으로 결과값을 계산한다.

즉, PurchaseOrderID가 결과값이었던 4006, 4007, 4008 3개의 값보다 큰 경우 결과를 출력하고, 결과적으로 MIN값인 4006보다 큰 경우를 계산한 것과 동일한 결과임을 확인할 수 있다. 

--################################
-- SUBQUERY - ANY
--################################
SELECT *
FROM [AdventureWorks2014].[Purchasing].[PurchaseOrderDetail]
WHERE PurchaseOrderID >= ANY (
	SELECT PurchaseOrderID
	FROM [AdventureWorks2014].[Purchasing].[PurchaseOrderHeader]
	WHERE RevisionNumber > 10
)
ORDER BY PurchaseOrderID

SELECT *
FROM [AdventureWorks2014].[Purchasing].[PurchaseOrderDetail]
WHERE PurchaseOrderID >= (4006)
ORDER BY PurchaseOrderID

SUBQUERY - ALL 결과 -> 4006 이상 출력

 

 

728x90
LIST
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/05   »
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 31
글 보관함