IN - Testing Values Returned by a Subquery in SQL Server

Q

How To Test Values Returned by a Subquery with the IN Operator in SQL Server Transact-SQL?

✍: FYIcenter.com

A

Normally, the comparison operator IN is used against a list of specified values as in the format of: "test_value IN (value_1, value_2, ..., value_n)". But you can also replace the list of values by a subquery as the following formats:

test_value IN (SELECT column FROM ...) 
-- Returns TRUE if the test_value equals to one of 
   the values returned from the subquery

test_value NOT IN (SELECT column FROM ...) 
-- Returns TRUE if the test_value does not equal to any of 
   the values returned from the subquery

The following tutorial exercise shows you two examples of IN operators. The sample database AdventureWorksLT provided by Microsoft is used.

USE adventureWorksLT
GO

SELECT COUNT(*) FROM SalesLT.Customer c
WHERE c.CustomerID IN (
   SELECT s.CustomerID FROM SalesLT.SalesOrderHeader s
   )
GO
32

SELECT COUNT(*) FROM SalesLT.Customer c
WHERE c.CustomerID NOT IN (
   SELECT s.CustomerID FROM SalesLT.SalesOrderHeader s
   )
GO
408

 

What Are Logical/Boolean Operations in SQL Server

EXISTS - Testing Subquery Results in SQL Server

Boolean Values and Logical Operations in SQL Server Transact-SQL

⇑⇑ SQL Server Transact-SQL Tutorials

2017-01-21, 1480🔥, 0💬