Preamble
The SQL condition IN (sometimes called the IN operator) makes it easy to check if the expression matches a value in the list of values. It is used to help reduce the need for multiple OR conditions in a SELECT, INSERT, UPDATE or DELETE operator.
Syntax of IN condition in SQL
expression_id IN (value1_id, value2_id, ... value_n_id);
Or:
expression_id IN (subquery_id);
where:
- IN (subquery_id) – Parameters or arguments
- expression_id – It’s a value for testing.
- value1_id, value2_id …, value_n_id – These are the values to check for conformity. If any of these values match an expression, the IN condition will have the value true.
- subquery_id – The subprocess is a SELECT operator, whose set of results will be checked for c compliance. If any of these values match, the IN condition will have the value true.
Using IN condition with character values
IN condition can be used with any data type in SQL. Let’s see how to use the IN condition with character (string) values.
In this example, we have a table with the following data:
| suppl_id | suppl_name | city_id | state_id |
| 100 | Yandex | Moscow | Russian |
| 200 | Lansing | Michigan | |
| 300 | Oracle | Redwood City | California |
| 400 | Bing | Redmond | Washington |
| 500 | Yahoo | Sunnyvale | Washington |
| 600 | DuckDuckGo | Paoli | Pennsylvania |
| 700 | Qwant | Paris | France |
| 800 | Menlo Park | California | |
| 900 | Electronic Arts | San Francisco | California |
Enter the following SQL statement:
SELECT *
FROM suppls
WHERE suppl_name IN ('Yandex', 'Oracle', 'Facebook');
Three entries will be selected. Here are the results you should get:
| suppl_id | suppl_name | city_id | state_id |
| 100 | Yandex | Moscow | Russian |
| 300 | Oracle | Redwood City | California |
| 800 | Menlo Park | California |
In this example, all rows from the suppls table will be returned, where suppl_name is Yandex, Oracle or Facebook. Since SELECT uses *, all fields from the table will be displayed in the result set.
This is equivalent to the next SQL statement:
SELECT *
FROM suppls
WHERE suppl_name = 'Yandex'
OR suppl_name = 'Oracle'
OR suppl_name = 'Facebook';
As you can see, using the IN condition makes the operator easier to read and more efficient than using multiple OR conditions.
Using the IN condition with numeric values
Next, let’s look at how to use the IN condition with numerical values.
In this example, we have a table and the following data:
| custom_id | f_name | l_name | f_website |
| 4000 | Justin | Bieber | google.com |
| 5000 | Selena | Gomez | bing.com |
| 6000 | Mila | Kunis | yahoo.com |
| 7000 | Tom | Cruise | oracle.com |
| 8000 | Johnny | Depp | NULL |
| 9000 | Russell | Crowe | google.com |
Enter the following SQL statement:
SELECT *
FROM customs
WHERE custom_id IN (5000, 7000, 8000, 9000);
Four records will be selected. Here are the results that you should get:
| custom_id | f_name | l_name | fav_website |
| 5000 | Selena | Gomez | bing.com |
| 7000 | Tom | Cruise | oracle.com |
| 8000 | Johnny | Depp | NULL |
| 9000 | Russell | Crowe | google.com |
In this example, all records from the custom_id table where custom_id is 5000, 7000, 8000 or 9000 will be returned.
This is equivalent to the next SQL statement:
SELECT *
FROM customs
WHERE custom_id = 5000
OR custom_id = 7000
OR custom_id = 8000
OR custom_id = 9,000;
Using IN condition with NOT operator
Finally, let’s see how to use the IN condition with the NOT operator. The NOT operator is used to override the condition. When we use the NOT operator with the IN condition, we create the NOT IN condition. This checks to see if the expression is not in the list.
In this example, we have a product table with the following data:
| prod_id | prod_name | cat_id |
| 1 | Pear | 50 |
| 2 | Banana | 50 |
| 3 | Orange | 50 |
| 4 | Apple | 50 |
| 5 | Bread | 75 |
| 6 | Sliced Ham | 25 |
| 7 | Kleenex | NULL |
Enter the following SQL statement:
SELECT *
FROM prods
WHERE prod_name NOT IN ('Pear', 'Banana', 'Bread');
Four entries will be selected. Here are the results you will get:
| prod_id | prod_name | cat_id |
| 3 | Orange | 50 |
| 4 | Apple | 50 |
| 6 | Sliced Ham | 25 |
| 7 | Kleenex | NULL |
This example will return all rows from the products table where prod_name is not Pear, Banana or Bread. Sometimes it is more efficient to list the values that you do not want, as opposed to the values that you want.
This is equivalent to the next SQL statement:
SELECT *
FROM prods
WHERE prod_name <> 'Pear'
AND prod_name <> 'Banana'
AND prod_name <> 'Bread';
As you can see, the equivalent operator is written using the AND condition instead of the OR condition because the IN condition is cancelled.
About Enteros
Enteros offers a patented database performance management SaaS platform. It finds the root causes of complex database scalability and performance problems that affect business across a growing number of cloud, RDBMS, NoSQL, and machine learning database platforms.
The views expressed on this blog are those of the author and do not necessarily reflect the opinions of Enteros Inc. This blog may contain links to the content of third-party sites. By providing such links, Enteros Inc. does not adopt, guarantee, approve, or endorse the information, views, or products available on such sites.
Are you interested in writing for Enteros’ Blog? Please send us a pitch!
RELATED POSTS
$11B at Stake — How Supply-Chain Delays Are Forcing Airlines to Fly Older Planes
- 7 November 2025
- Software Engineering
Introduction The aviation industry is entering 2025 at a critical inflection point. According to a joint report by the International Air Transport Association (IATA) and Oliver Wyman, global airlines could face over $11 billion in additional costs this year due to persistent supply-chain disruptions. The most visible consequence is the forced reliance on older, less … Continue reading “$11B at Stake — How Supply-Chain Delays Are Forcing Airlines to Fly Older Planes”
Enhancing Cost Estimation and Attribution in the Technology Sector: How Enteros Uses AI Performance Management to Drive Financial and Operational Efficiency
- 6 November 2025
- Database Performance Management
Introduction In the dynamic world of the technology sector, cost estimation and attribution have become as critical as innovation itself. As companies expand their cloud infrastructures, deploy AI-driven workloads, and manage vast databases across multi-cloud ecosystems, the challenge lies in maintaining both financial precision and performance optimization. Technology enterprises need a clear understanding of where … Continue reading “Enhancing Cost Estimation and Attribution in the Technology Sector: How Enteros Uses AI Performance Management to Drive Financial and Operational Efficiency”
Optimizing Retail Budgeting and Performance: How Enteros Combines AI SQL and AI Performance Management to Transform Database Efficiency
Introduction In the fast-paced retail sector, success depends on delivering seamless customer experiences, managing inventory efficiently, and controlling operational costs — all while keeping up with dynamic market demands. Retailers today rely on a digital ecosystem powered by databases, SaaS platforms, and AI technologies to manage everything from transactions and supply chains to personalized recommendations. … Continue reading “Optimizing Retail Budgeting and Performance: How Enteros Combines AI SQL and AI Performance Management to Transform Database Efficiency”
Revolutionizing the Fashion Sector: How Enteros Leverages Generative AI and AI Performance Management to Optimize SaaS Database Efficiency
- 5 November 2025
- Database Performance Management
Introduction The global fashion industry has always been a beacon of creativity, speed, and transformation. From runway collections to e-commerce platforms, the sector thrives on rapid innovation and data-driven decision-making. In today’s digital-first world, fashion enterprises—from luxury retailers to fast-fashion brands—are evolving into technology-driven organizations, heavily dependent on SaaS platforms, AI tools, and cloud databases … Continue reading “Revolutionizing the Fashion Sector: How Enteros Leverages Generative AI and AI Performance Management to Optimize SaaS Database Efficiency”