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
How to Enable Data-Driven Media Growth with Enteros Cost Attribution and Software Management
- 22 June 2026
- Software Engineering
Introduction The media industry is experiencing one of the most significant transformations in its history. Streaming services, digital publishing platforms, online advertising ecosystems, video-on-demand applications, and content distribution networks have fundamentally changed how audiences consume content. Modern media organizations now operate highly complex digital ecosystems that support: Streaming platforms Digital publishing systems Video content delivery … Continue reading “How to Enable Data-Driven Media Growth with Enteros Cost Attribution and Software Management”
How to Enable Intelligent Wealth Management Operations with Enteros Database Software, AIOps Platform, and Gen AI
Introduction The wealth management industry is undergoing a major transformation. As investors demand personalized financial services, real-time portfolio visibility, and digital-first experiences, wealth management firms are increasingly relying on technology to drive operational efficiency, improve client engagement, and accelerate business growth. Modern wealth management organizations now support: Portfolio management platforms Wealth advisory applications Digital client … Continue reading “How to Enable Intelligent Wealth Management Operations with Enteros Database Software, AIOps Platform, and Gen AI”
The Future of Database Observability in Hybrid Cloud Environments
As enterprises accelerate digital transformation, hybrid cloud infrastructure has become the preferred operating model for many organizations. Instead of relying solely on on-premises data centers or fully public cloud deployments, businesses increasingly combine both environments to achieve greater flexibility, scalability, performance, and cost efficiency. Hybrid cloud enables organizations to distribute workloads strategically across private infrastructure … Continue reading “The Future of Database Observability in Hybrid Cloud Environments”
How AI-Powered Database Analytics Improves Digital Customer Experience
In today’s digital-first economy, customer experience has become one of the strongest differentiators for businesses. Whether customers are shopping online, using banking apps, booking travel, streaming media, or accessing SaaS platforms, they expect fast, seamless, and reliable digital interactions at every touchpoint. Modern users have little tolerance for delays. A slow-loading webpage, failed transaction, delayed … Continue reading “How AI-Powered Database Analytics Improves Digital Customer Experience”