How to use the IN operator
Figure 3-12 shows how to code a WHERE clause that uses the IN operator. When you use this operator, the value of the test expression is compared with the list of expressions in the IN phrase. If the test expression is equal to one of the expressions in the list, the row is included in the query results. This is illustrated by the first example in this figure, which will return all rows whose TermsID column is equal to 1, 3, or 4.
You can also use the NOT operator with the IN phrase to test for a value that's not in a list of expressions. This is illustrated by the second example in this figure. In this case, only those vendors who are not in California, Nevada, or Oregon are retrieved.
If you look at the syntax of the IN phrase shown at the top of this figure, you'll see that you can code a subquery in place of a list of expressions. Subqueries are a powerful tool that you'll learn about in detail in chapter 6. For now, though, you should know that a subquery is simply a SELECT statement within another statement. In the third example in this figure, for instance, a subquery is used to return a list of VendorID values for vendors who have invoices dated May 1, 2008. Then, the WHERE clause retrieves a vendor row only if the vendor is in that list. Note that for this to work, the subquery must return a single column, in this case, VendorID.
The syntax of the WHERE clause with an IN phrase
WHERE test_expression [NOT] IN ({subquery|expression_1 [, expression_2]...})
Examples of the IN phrase
An IN phrase with a list of numeric literalsWHERE TermsID IN (1, 3, 4) An IN phrase preceded by NOTWHERE VendorState NOT IN ('CA', 'NV', 'OR') An IN phrase with a subqueryWHERE VendorID IN(SELECT VendorIDFROM InvoicesWHERE InvoiceDate = '2008-05-01')
An IN phrase with a list of numeric literalsWHERE TermsID IN (1, 3, 4)
An IN phrase preceded by NOTWHERE VendorState NOT IN ('CA', 'NV', 'OR')
An IN phrase with a subqueryWHERE VendorID IN(SELECT VendorIDFROM InvoicesWHERE InvoiceDate = '2008-05-01')
Description
Figure 3-12 How to use the IN operator