 
- SQL - Home
- SQL - Roadmap
- SQL - Overview
- SQL - RDBMS Concepts
- SQL - Databases
- SQL - Syntax
- SQL - Data Types
- SQL - Operators
- SQL - Expressions
- SQL - Comments
- SQL Database
- SQL - Create Database
- SQL - Drop Database
- SQL - Select Database
- SQL - Rename Database
- SQL - Show Databases
- SQL - Backup Database
- SQL Table
- SQL - Create Table
- SQL - Show Tables
- SQL - Rename Table
- SQL - Truncate Table
- SQL - Clone Tables
- SQL - Temporary Tables
- SQL - Alter Tables
- SQL - Drop Table
- SQL - Delete Table
- SQL - Constraints
- SQL Queries
- SQL - Insert Query
- SQL - Select Query
- SQL - Select Into
- SQL - Insert Into Select
- SQL - Update Query
- SQL - Delete Query
- SQL - Sorting Results
- SQL Views
- SQL - Create Views
- SQL - Update Views
- SQL - Drop Views
- SQL - Rename Views
- SQL Operators and Clauses
- SQL - Where Clause
- SQL - Top Clause
- SQL - Distinct Clause
- SQL - Order By Clause
- SQL - Group By Clause
- SQL - Having Clause
- SQL - AND & OR
- SQL - BOOLEAN (BIT) Operator
- SQL - LIKE Operator
- SQL - IN Operator
- SQL - ANY, ALL Operators
- SQL - EXISTS Operator
- SQL - CASE
- SQL - NOT Operator
- SQL - NOT EQUAL
- SQL - IS NULL
- SQL - IS NOT NULL
- SQL - NOT NULL
- SQL - BETWEEN Operator
- SQL - UNION Operator
- SQL - UNION vs UNION ALL
- SQL - INTERSECT Operator
- SQL - EXCEPT Operator
- SQL - Aliases
- SQL Joins
- SQL - Using Joins
- SQL - Inner Join
- SQL - Left Join
- SQL - Right Join
- SQL - Cross Join
- SQL - Full Join
- SQL - Self Join
- SQL - Delete Join
- SQL - Update Join
- SQL - Left Join vs Right Join
- SQL - Union vs Join
- SQL Keys
- SQL - Unique Key
- SQL - Primary Key
- SQL - Foreign Key
- SQL - Composite Key
- SQL - Alternate Key
- SQL Indexes
- SQL - Indexes
- SQL - Create Index
- SQL - Drop Index
- SQL - Show Indexes
- SQL - Unique Index
- SQL - Clustered Index
- SQL - Non-Clustered Index
- Advanced SQL
- SQL - Wildcards
- SQL - Injection
- SQL - Hosting
- SQL - Min & Max
- SQL - Null Functions
- SQL - Check Constraint
- SQL - Default Constraint
- SQL - Stored Procedures
- SQL - NULL Values
- SQL - Transactions
- SQL - Sub Queries
- SQL - Handling Duplicates
- SQL - Using Sequences
- SQL - Auto Increment
- SQL - Date & Time
- SQL - Cursors
- SQL - Common Table Expression
- SQL - Group By vs Order By
- SQL - IN vs EXISTS
- SQL - Database Tuning
- SQL Function Reference
- SQL - Date Functions
- SQL - String Functions
- SQL - Aggregate Functions
- SQL - Numeric Functions
- SQL - Text & Image Functions
- SQL - Statistical Functions
- SQL - Logical Functions
- SQL - Cursor Functions
- SQL - JSON Functions
- SQL - Conversion Functions
- SQL - Datatype Functions
- SQL Useful Resources
- SQL - Questions and Answers
- SQL - Cheatsheet
- SQL - Quick Guide
- SQL - Useful Functions
- SQL - Useful Resources
- SQL - Discussion
SQL - NOT Operator
The SQL NOT Operator
The NOT operator in SQL is used to negate a condition, meaning it returns rows where the specified condition is not true. It is applied with comparison and logical operators to filter out certain values or ranges. For example:
- NOT = excludes rows with a specific value.
- NOT IN excludes rows matching any value in a given list.
- NOT LIKE excludes rows matching a specific pattern.
- NOT BETWEEN excludes rows within a given range.
By using NOT operator, you can refine query results to include only data that does not meet certain criteria.
Syntax
Following is the syntax for SQL NOT operator:
SELECT column1, column2, ... FROM table_name WHERE NOT condition;
Example
In the following example, let us first create a table to demonstrate the usage of NOT operator.
Using the query below, we are creating a table named CUSTOMERS, which contains the personal details of customers including their name, age, address and salary etc.:
CREATE TABLE CUSTOMERS ( ID INT NOT NULL, NAME VARCHAR (20) NOT NULL, AGE INT NOT NULL, ADDRESS CHAR (25), SALARY DECIMAL (18, 2), PRIMARY KEY (ID) );
Now, insert values into this table using the INSERT statement as follows:
INSERT INTO CUSTOMERS VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000.00 ), (2, 'Khilan', 25, 'Delhi', 1500.00 ), (3, 'Kaushik', 23, 'Kota', 2000.00 ), (4, 'Chaitali', 25, 'Mumbai', 6500.00 ), (5, 'Hardik', 27, 'Bhopal', 8500.00 ), (6, 'Komal', 22, 'Hyderabad', 4500.00 ), (7, 'Muffy', 24, 'Indore', 10000.00 );
The table will be created as follows:
| ID | NAME | AGE | ADDRESS | SALARY | 
|---|---|---|---|---|
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 | 
| 2 | Khilan | 25 | Delhi | 1500.00 | 
| 3 | Kaushik | 23 | Kota | 2000.00 | 
| 4 | Chaitali | 25 | Mumbai | 6500.00 | 
| 5 | Hardik | 27 | Bhopal | 8500.00 | 
| 6 | Komal | 22 | Hyderabad | 4500.00 | 
| 7 | Muffy | 24 | Indore | 10000.00 | 
The SQL query below retrieves all rows from the 'CUSTOMERS' table where the 'SALARY' column is not greater than 2000.00:
SELECT * FROM CUSTOMERS WHERE NOT (SALARY > 2000.00);
Following is the output of the above query:
| ID | NAME | AGE | ADDRESS | SALARY | 
|---|---|---|---|---|
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 | 
| 2 | Khilan | 25 | Delhi | 1500.00 | 
| 3 | Kaushik | 23 | Kota | 2000.00 | 
SQL NOT with LIKE Operator
We can use the SQL NOT keyword with the LIKE operator to find rows that do not match a specific pattern.
While LIKE searches for values that fit a given pattern using wildcards (% for multiple characters, _ for a single character), NOT LIKE returns the opposite, i.e. only rows that fail to match that pattern.
Example
We use the following query to retrieve all rows from the 'CUSTOMERS' table where the 'NAME' column does not start with the letter 'K':
SELECT * FROM CUSTOMERS WHERE NAME NOT LIKE 'K%';
On executing the query above, the table will be displayed as follows:
| ID | NAME | AGE | ADDRESS | SALARY | 
|---|---|---|---|---|
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 | 
| 4 | Chaitali | 25 | Mumbai | 6500.00 | 
| 5 | Hardik | 27 | Bhopal | 8500.00 | 
| 7 | Muffy | 24 | Indore | 10000.00 | 
SQL NOT with IN Operator
The NOT keyword can be used with the IN operator to exclude rows where a column's value matches any value in a specified list.
While IN returns rows with values found in the list, NOT IN returns only those that are not in the list.
Example
The following SQL query selects all rows from the 'CUSTOMERS' table where the 'AGE' column does not have values 25, 26, or 32:
SELECT * FROM CUSTOMERS WHERE AGE NOT IN (25, 26, 32);
The result table is displayed as follows:
| ID | NAME | AGE | ADDRESS | SALARY | 
|---|---|---|---|---|
| 3 | Kaushik | 23 | Kota | 2000.00 | 
| 5 | Hardik | 27 | Bhopal | 8500.00 | 
| 6 | Komal | 22 | Hyderabad | 4500.00 | 
| 7 | Muffy | 24 | Indore | 10000.00 | 
SQL NOT with IS NULL Operator
The NOT keyword can be used with the IS NULL operator to find rows where a column does not contain NULL values.
Since NULL represents missing or unknown data in SQL, NOT IS NULL returns only rows with actual (non-null) values.
Example
This SQL query retrieves all rows from the 'CUSTOMERS' table where the 'AGE' column is not null, i.e. it contains valid age values:
SELECT * FROM CUSTOMERS WHERE AGE IS NOT NULL;
The result table is exactly as the original table as it contains no NULL values:
| ID | NAME | AGE | ADDRESS | SALARY | 
|---|---|---|---|---|
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 | 
| 2 | Khilan | 25 | Delhi | 1500.00 | 
| 3 | Kaushik | 23 | Kota | 2000.00 | 
| 4 | Chaitali | 25 | Mumbai | 6500.00 | 
| 5 | Hardik | 27 | Bhopal | 8500.00 | 
| 6 | Komal | 22 | Hyderabad | 4500.00 | 
| 7 | Muffy | 24 | Indore | 10000.00 | 
However, if the table contains any NULL values, the rows containing it will be omitted in the resultant table.
SQL NOT with BETWEEN Operator
The NOT keyword can be used with the BETWEEN operator to exclude rows where a column's value falls within a specific range.
While BETWEEN returns values within the range (inclusive), NOT BETWEEN returns values outside that range.
Example
Using the following query, we are displaying records in the CUSTOMERS table whose salary does not fall between 1500.00 and 2500.00:
SELECT * FROM CUSTOMERS WHERE SALARY NOT BETWEEN 1500.00 AND 2500.00;
The resultant table is as follows:
| ID | NAME | AGE | ADDRESS | SALARY | 
|---|---|---|---|---|
| 4 | Chaitali | 25 | Mumbai | 6500.00 | 
| 5 | Hardik | 27 | Bhopal | 8500.00 | 
| 6 | Komal | 22 | Hyderabad | 4500.00 | 
| 7 | Muffy | 24 | Indore | 10000.00 | 
SQL NOT with EXISTS Operator
The NOT keyword can be used with the EXISTS operator to return rows where a subquery does not produce any results. While EXISTS returns TRUE if the subquery finds matching rows, NOT EXISTS returns TRUE only when the subquery finds none.
Example
In the following example, let us create another table Orders to help in demonstrating the usage of NOT operator with EXISTS operator:
CREATE TABLE ORDERS ( OID INT NOT NULL, DATE VARCHAR (20) NOT NULL, CUSTOMER_ID INT NOT NULL, AMOUNT DECIMAL (18, 2) );
Using the INSERT statement, insert values into this table as follows:
INSERT INTO ORDERS VALUES (102, '2009-10-08 00:00:00', 3, 3000.00), (100, '2009-10-08 00:00:00', 3, 1500.00), (101, '2009-11-20 00:00:00', 2, 1560.00), (103, '2008-05-20 00:00:00', 4, 2060.00);
The table is displayed as follows:
| OID | DATE | CUSTOMER_ID | AMOUNT | 
|---|---|---|---|
| 102 | 2009-10-08 00:00:00 | 3 | 3000.00 | 
| 100 | 2009-10-08 00:00:00 | 3 | 1500.00 | 
| 101 | 2009-11-20 00:00:00 | 2 | 1560.00 | 
| 103 | 2008-05-20 00:00:00 | 4 | 2060.00 | 
Following query is used to print the IDs of customers in CUSTOMERS table that do not exist in the ORDERS table:
SELECT * FROM CUSTOMERS WHERE NOT EXISTS ( SELECT CUSTOMER_ID FROM ORDERS WHERE ORDERS.CUSTOMER_ID = CUSTOMERS.ID);
The output obtained after executing the query is as follows:
| ID | NAME | AGE | ADDRESS | SALARY | 
|---|---|---|---|---|
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 | 
| 5 | Hardik | 27 | Bhopal | 8500.00 | 
| 6 | Komal | 22 | Hyderabad | 4500.00 | 
| 7 | Muffy | 24 | Indore | 10000.00 | 
SQL NOT with Greater Than Operator
The NOT keyword can be used with the Greater Than (>) operator to return rows where a column's value is not greater than a given number.
While > returns values strictly greater than the specified number, NOT (> value) returns the opposite, i.e. values that are either less than or equal to that number.
Example
In the following query, we retrieve all customers whose salary is not greater than 5000.00:
SELECT * FROM CUSTOMERS WHERE NOT (SALARY > 5000.00);
The resultant table will be as follows:
| ID | NAME | AGE | ADDRESS | SALARY | 
|---|---|---|---|---|
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 | 
| 2 | Khilan | 25 | Delhi | 1500.00 | 
| 3 | Kaushik | 23 | Kota | 2000.00 | 
| 6 | Komal | 22 | Hyderabad | 4500.00 | 
SQL NOT with Less Than Operator
The NOT keyword can be used with the Less Than (<) operator to return rows where a column's value is not less than a given number.
While < returns values strictly smaller than the specified number, NOT (< value) returns the opposite, i.e. values that are greater than or equal to that number.
Example
The following query retrieves all customers whose age is not less than 25:
SELECT * FROM CUSTOMERS WHERE NOT (AGE < 25);
The output is as follows:
| ID | NAME | AGE | ADDRESS | SALARY | 
|---|---|---|---|---|
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 | 
| 2 | Khilan | 25 | Delhi | 1500.00 | 
| 4 | Chaitali | 25 | Mumbai | 6500.00 | 
| 5 | Hardik | 27 | Bhopal | 8500.00 | 
SQL NOT with AND Operator
The NOT keyword can also be used with the AND logical operator to negate a compound condition.
When used with AND, the NOT operator reverses the truth value of the combined conditions. In other words, NOT (condition1 AND condition2) returns rows where at least one of the conditions is false.
Example
The following query retrieves all customers whose age is not between 25 and 30 inclusive, when combined with a salary condition, by negating the AND logic:
SELECT * FROM CUSTOMERS WHERE NOT (AGE >= 25 AND SALARY >= 5000.00);
The result table is shown below:
| ID | NAME | AGE | ADDRESS | SALARY | 
|---|---|---|---|---|
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 | 
| 2 | Khilan | 25 | Delhi | 1500.00 | 
| 3 | Kaushik | 23 | Kota | 2000.00 | 
| 6 | Komal | 22 | Hyderabad | 4500.00 | 
| 7 | Muffy | 24 | Indore | 10000.00 |