 
 Data Structure Data Structure
 Networking Networking
 RDBMS RDBMS
 Operating System Operating System
 Java Java
 MS Excel MS Excel
 iOS iOS
 HTML HTML
 CSS CSS
 Android Android
 Python Python
 C Programming C Programming
 C++ C++
 C# C#
 MongoDB MongoDB
 MySQL MySQL
 Javascript Javascript
 PHP PHP
- Selected Reading
- UPSC IAS Exams Notes
- Developer's Best Practices
- Questions and Answers
- Effective Resume Writing
- HR Interview Questions
- Computer Glossary
- Who is Who
How to Select All Records from One Table That Do Not Exist in Another Table in SQL?
In SQL, there are several ways to achieve this, including using LEFT JOIN, NOT EXISTS, and NOT IN. This article will explore these methods in detail, providing examples and guidance on when to use each approach.
1. Using LEFT JOIN with IS NULL
The LEFT JOIN operation returns all records from the left table (the first table) and the matching records from the right table (the second table). When no match is found, the result will include NULL values for the right table's columns. This feature allows you to easily identify records in the first table that do not have a matching record in the second table.
Read also: SQL IS NULL
Syntax
SELECT a.* FROM table1 a LEFT JOIN table2 b ON a.id = b.id WHERE b.id IS NULL;
Explanation
- table1 is the table from which you want to select all records.
- table2 is the table that you are comparing against.
- The LEFT JOIN ensures that all records from table1 are included, even if there is no match in table2.
- The WHERE b.id IS NULL condition filters the records to show only those that do not have a corresponding entry in table2.
Example
Let's say you have two tables, employees and departments, and you want to find employees who are not assigned to any department. The query would look like this:
SELECT e.id, e.name FROM employees e LEFT JOIN departments d ON e.id = d.id WHERE d.id IS NULL;
This query will return the list of employees who do not belong to any department.
2. Using NOT EXISTS
The NOT EXISTS clause is another powerful way to filter records from one table based on the absence of corresponding records in another table. It works by executing a subquery that checks whether a condition is met for each row in the outer query.
Syntax
SELECT *
FROM table1 a
WHERE NOT EXISTS (
    SELECT 1
    FROM table2 b
    WHERE a.id = b.id
);
Explanation
- The outer query selects records from table1.
- The NOT EXISTS subquery checks if there is no corresponding record in table2 for each record from table1.
- If no match is found, the record from table1 is included in the result.
Example
Using the same employees and departments example, the query to find employees not assigned to a department would be:
SELECT e.id, e.name
FROM employees e
WHERE NOT EXISTS (
    SELECT 1
    FROM departments d
    WHERE e.id = d.id
);
This query will produce the same result as the LEFT JOIN method, showing employees with no department assigned.
3. Using NOT IN
The NOT IN operator allows you to filter records by checking if a value in a column is not in a list of values returned by a subquery. While simple, this method can sometimes be less efficient compared to the other approaches, especially when dealing with larger datasets.
Syntax
SELECT * FROM table1 a WHERE a.id NOT IN (SELECT b.id FROM table2 b);
Explanation
- This query selects records from table1 where the id is not present in the list of ids returned by the subquery from table2.
- If the id in table1 does not exist in table2, it will be included in the result.
Example
To find employees without a department using the NOT IN approach:
SELECT e.id, e.name FROM employees e WHERE e.id NOT IN (SELECT d.id FROM departments d);
While this query works well for small datasets, it may encounter issues if the subquery returns NULL values, as it may exclude records unintentionally.
When to Use Each Method
- LEFT JOIN with IS NULL: This is the most widely used method as it is easy to understand and often performs well, especially for large datasets. It is preferred when you want to select all records from the first table and compare them to a second table.
- NOT EXISTS: This is often more efficient for complex queries, especially when dealing with subqueries or when the second table contains a lot of data. It's preferred when you need a more flexible or optimized solution.
- NOT IN: This method can be simpler but may suffer from performance issues when the subquery includes NULL values. It's useful when dealing with small datasets or simple comparisons.
Conclusion
Selecting records from one table that do not exist in another is a common task in SQL. Whether you use LEFT JOIN, NOT EXISTS, or NOT IN depends on the complexity of your query and the structure of your data. By understanding the advantages and drawbacks of each method, you can choose the best approach for your specific scenario. Practice and understanding of these techniques will improve your ability to work with relational databases efficiently.
