EXISTS and NOT EXISTS are used with a subquery in the WHERE clause to examine if the result the subquery returns is TRUE or FALSE. It will identify the existence of a relationship without regard for quantity. For example, if the subquery returns at least one record in its result set, the EXISTS clause will evaluate to true and the condition will be met. If the subquery does not return any records, the EXISTS clause will evaluate as false and the condition will not be met. Because both are used with correlated subqueries, the subquery executes once for every row in the outer query. In other words, for each row in the outer query, by using information from the outer query, the subquery checks if it returns TRUE or FALSE, and then the value is returned to the outer query to use.
Notes
SELECT [Column Names] FROM [Source] WHERE EXISTS (Write Sub-query to Check)
Columns: It allows us to choose the number of columns from the tables. It may be One or more.
Source: One or more tables present in the Database. SQL JOINS are used to join multiple tables.
Subquery: Here we have to provide the Subquery. If the subquery returns true then it will return the records otherwise, it doesn’t return any records.
Table: customers
customer_id | customer_nm | address | city | Zip | country |
1 | Alex Angles | 230 Erwin Street | Woodland Hills | 91367 | USA |
2 | Frank Wilson | New Delhi Road | Delhi | 87653 | India |
3 | Daniel Perker | Hilton street | Paris | 75016 | France |
4 | Mark Punk | Italiano blvd | Berlin | 10101 | Italy |
5 | Thomas Wilson | 1007 N Jackson street | Milwakee | 78881 | USA |
Table: orders
order_id | customer_id | order_date | order_amt | Ship_id |
10001 | 1 | 2021-01-01 | 100.00 | 1 |
10002 | 5 | 2021-06-01 | 150.00 | 10 |
10003 | 3 | 2021-07-01 | 1000.00 | 3 |
10004 | 4 | 2021-07-15 | 250.50 | 2 |
10005 | 3 | 2021-08-01 | 225.50 | 5 |
SELECT * FROM customers WHERE EXISTS (SELECT * FROM orders WHERE customers.customer_id = orders.customer_id);
The above query will return all the customer IDs present in the order table. Except for customer id 2 rest of the customer IDs are present in the order table.
customer_id | customer_nm | address | city | Zip | country |
1 | Alex Angles | 230 Erwin Street | Woodland Hills | 91367 | USA |
3 | Daniel Perker | Hilton street | Paris | 75016 | France |
4 | Mark Punk | Italiano blvd | Berlin | 10101 | Italy |
5 | Thomas Wilson | 1007 N Jackson street | Milwakee | 78881 | USA |
UPDATE orders SET order_amt = order_amt + 10 WHERE EXISTS (SELECT customer_id FROM customers WHERE customers.customer_id = order.customer_id);
The above statement will update the order value in the orders table for those customers who are present in the customers table, by increasing the current order value by 10 dollars. The final orders table will be
order_id | customer_id | order_date | order_amt | Ship_id |
10001 | 1 | 2021-01-01 | 110.00 | 1 |
10002 | 5 | 2021-06-01 | 160.00 | 10 |
10003 | 3 | 2021-07-01 | 1010.00 | 3 |
10004 | 4 | 2021-07-15 | 260.50 | 2 |
10005 | 3 | 2021-08-01 | 235.50 | 5 |
DELETE FROM orders WHERE EXISTS (SELECT * FROM customers WHERE customers.customer_id = orders.customer_id AND customers.country = 'USA');
The above query will delete the customers who are from USA.
order_id | customer_id | order_date | order_amt | Ship_id |
10002 | 5 | 2021-06-01 | 150.00 | 10 |
10003 | 3 | 2021-07-01 | 1000.00 | 3 |
10004 | 4 | 2021-07-15 | 250.50 | 2 |
NOT condition can be combined with the EXISTS condition to create a NOT EXISTS condition. The NOT EXISTS phrases look for the non-existence of rows in the sub-query result set:
SELECT [Column Names] FROM [Source] WHERE NOT EXISTS (Write Subquery to Check)
SELECT * FROM customers WHERE NOT EXISTS (SELECT * FROM orders WHERE customers.customer_id = orders.customer_id);
This above query would return all records from the customers table where there are no records in the orders table for the given customer_id.Only 1 record with customer id 2 is not present in order table.
customer_id | customer_nm | address | city | Zip | country |
2 | Frank Wilson | New Delhi Road | Delhi | 87653 | India |
Table: STORE_SALES STORE_KEY | ORDER_NUMBER | CUST_KEY | SALES_AMT -----------+--------------+------------+----------- 166 | 36008 | 14818 | 150 9 | 188567 | 18222 | 35 45 | 202416 | 30333 | 10 113 | 66017 | 18705 | 200 199 | 111111 | 30999 | 300 166 | 121211 | 48999 | 500 198 | 75716 | 30231 | 199 27 | 150241 | 48353 | 599 148 | 182207 | 14111 | 50 24 | 250295 | 14999 | 799 121 | 251417 | 18999 | 999 121 | 199999 | 30999 | 700 Table: CUST_TABLE CUST_KEY | CUST_NAME | CUST_STATE --------------+--------------------+---------------- 18999 | James J. Goldberg | AL 30999 | Sarah N. McCabe | NJ 48999 | Mark L. Brown | MA 30231 | Sandy N. Fish | CA 48353 | Mark L. Man | CA 14111 | Cheryl X. Hills | TX 18222 | Kim J. Young | MA 30333 | Sunoj N. Samuel | CT 14818 | Sam X. Niel | CA 18705 | Jim J. Okimoto | CA 14999 | William X. Nielson | MA
1. The following query retrieves the list of all the customers who purchased anything from any of the stores amounting to more than 100 dollars & from CA state.
SELECT CUST_KEY, CUST_NAME, CUST_STATE FROM CUST_TABLE WHERE EXISTS (SELECT 1 FROM STORE_SALES WHERE STORE_SALES.CUST_KEY =CUST_TABLE.CUST_KEY AND SALES_AMT > 100) AND CUST_STATE = 'CA' ORDER BY CUST_KEY;
CUST_KEY | CUST_NAME | CUST_STATE --------------+--------------------+---------------- 14818 | Sam X. Niel | CA 18705 | Jim J. Okimoto | CA 30231 | Sandy N. Fish | CA 48353 | Mark L. Man | CA
2. The following query retrieves the list of all the customers who purchased anything from any of the stores amounting to less than 100 dollars & non-CA state.
SELECT CUST_KEY, CUST_NAME, CUST_STATE FROM CUST_TABLE WHERE NOT EXISTS (SELECT 1 FROM STORE_SALES WHERE STORE_SALES.CUST_KEY =CUST_TABLE.CUST_KEY AND SALES_AMT > 100) AND CUST_STATE <> 'CA' ORDER BY CUST_KEY;
CUST_KEY | CUST_NAME | CUST_STATE --------------+--------------------+---------------- 14111 | Cheryl X. Hills | TX 18222 | Kim J. Young | MA 30333 | Sunoj N. Samuel | CT
Here’s a complex example with explanations on EXISTS and NOT EXISTS subqueries:
Imagine a database containing tables for employees, departments, projects, and employee assignments to projects. We need to answer the following questions:
SELECT EmployeeID, EmployeeName FROM Employees E WHERE EXISTS ( SELECT * FROM Projects P JOIN Departments D ON P.DepartmentID = D.DepartmentID WHERE E.EmployeeID = P.EmployeeID GROUP BY P.DepartmentID HAVING COUNT(DISTINCT P.ProjectID) >= 2 -- Ensure multiple projects );
SELECT DepartmentID, DepartmentName FROM Departments D WHERE NOT EXISTS ( SELECT * FROM Projects P WHERE P.DepartmentID = D.DepartmentID AND P.ProjectStatus = 'Active' -- Filter for active projects );
Effective User interviews play a crucial role in Scrum methodology, helping Product Owners and Scrum…
Product Owners should be well-versed in various user research tools and techniques to effectively understand…
Effective Product Owner plays a crucial role in Agile development, acting as the bridge between…
A well-maintained product backlog is crucial for successful product development. It serves as a single…
Incremental value to the customer refers to the gradual delivery of small, functional parts of…
A Product Market refers to the group of potential customers who might be interested in…