EXCEPT

The SQL EXCEPT Operator

The EXCEPT operator in SQL is used to retrieve all the unique records from the left operand (query), except the records that are present in the result set of the right operand (query).

In other words, this operator compares the distinct values of the left query with the result set of the right query. If a value from the left query is found in the result set of the right query, it is excluded from the final result.

For better understanding consider two tables with records as shown in the following image −

Except

If we perform the EXCEPT operator on the above two tables to retrieve the names, it will display the distinct records only from the first table which are not in common with the records of the second table.

Here, “Dev” is common in both tables. So, the EXECPT operator will eliminate it and retrieves only “Sara” and “Jay” as output.

MySQL database does not support the EXCEPT operator. Instead of this, we can use the DISTINCT keyword along with the LEFT JOIN clause to retrieve distinct values from the left table.

Syntax

Following is the SQL syntax of the EXCEPT operator in Microsoft SQL server −

SELECT column1, column2,..., columnN
FROM table1, table2,..., tableN
[Conditions]//optionalEXCEPTSELECT column1, column2,..., columnN
FROM table1, table2,..., tableN
[Conditions]//optional

The number and order of columns in both SELECT statements should be the same.

Example

First of all, let us create a table named STUDENTS using the following query −

CREATETABLE STUDENTS(
   ID INTNOTNULL, 
   NAME VARCHAR(20)NOTNULL, 
   SUBJECT VARCHAR(20)NOTNULL, 
   AGE INTNOTNULL, 
   HOBBY VARCHAR(20)NOTNULL,PRIMARYKEY(ID));

Let’s insert some values into the table using the following query −

INSERTINTO STUDENTS VALUES(1,'Naina','Maths',24,'Cricket'),(2,'Varun','Physics',26,'Football'),(3,'Dev','Maths',23,'Cricket'),(4,'Priya','Physics',25,'Cricket'),(5,'Aditya','Chemistry',21,'Cricket'),(6,'Kalyan','Maths',30,'Football'),(7,'Aditya','Chemistry',21,'Cricket'),(8,'Kalyan','Chemistry',32,'Cricket');

The table produced is as shown below −

IDNAMESUBJECTAGEHOBBY
1NainaMathematics24Cricket
2VarunPhysics26Football
3DevMathematics23Cricket
4PriyaPhysics25Cricket
5AdityaChemistry21Cricket
6KalyanMathematics30Football
7AdityaChemistry21Cricket
8KalyanChemistry32Cricket

Now, let us create another table named STUDENTS_HOBBY using the following query −

CREATETABLE STUDENTS_HOBBY(
   ID INTNOTNULL, 
   NAME VARCHAR(20)NOTNULL, 
   HOBBY VARCHAR(20)NOTNULL, 
   AGE INTNOTNULL,PRIMARYKEY(ID));

Once the table is created, let us insert some values to the table using the query below −

INSERTINTO STUDENTS_HOBBY VALUES(1,'Vijay','Cricket',18),(2,'Varun','Football',26),(3,'Surya','Cricket',19),(4,'Karthik','Cricket',25),(5,'Sunny','Football',26),(6,'Dev','Cricket',23);

The table created is as follows −

IDNAMEHOBBYAGE
1VijayCricket18
2VarunFootball26
3SuryaCricket19
4KarthikCricket25
5SunnyFootball26
6DevCricket23

Now, let us perform the except operation on the above two tables −

SELECT NAME, HOBBY, AGE FROM STUDENTS
EXCEPTSELECT NAME, HOBBY, AGE FROM STUDENTS_HOBBY;

Output

Output of the above query is as shown below −

NAMEHOBBYAGE
AdityaCricket21
KalyanCricket32
KalyanFootball30
NainaCricket24
PriyaCricket25

EXCEPT with BETWEEN Operator

We can use the EXCEPT operator with the BETWEEN operator in SQL to exclude records that fall within a specified range.

Example

In the following SQL query, we are retrieving the records of students aged between 20 and 30 from the STUDENTS table, excluding those who are also aged between 20 and 30 from the STUDENTS_HOBBY table −

SELECT NAME, HOBBY, AGE
FROM STUDENTS
WHERE AGE BETWEEN20AND30EXCEPTSELECT NAME, HOBBY, AGE 
FROM STUDENTS_HOBBY
WHERE AGE BETWEEN20AND30

Output

When we execute the program query, the output is obtained as follows −

NAMEHOBBYAGE
AdityaCricket21
KalyanFootball30
NainaCricket24
PriyaCricket25

Except with IN Operator

The IN operator is used to filter a result set based on a list of specified values. We can also use the EXCEPT operator with the IN operator in SQL to exclude records that matches values in the specified list.

Example

Here, we are retrieving the records of students with Cricket as a hobby, from the STUDENTS table, excluding those who also have Cricket as hobby from the STUDENTS_HOBBY table −

SELECT NAME, HOBBY, AGE FROM STUDENTS
WHERE HOBBY IN('Cricket')EXCEPTSELECT NAME, HOBBY, AGE FROM STUDENTS_HOBBY
WHERE HOBBY IN('Cricket')

Output

Following is the output of the above query −

NAMEHOBBYAGE
AdityaCricket21
KalyanCricket32
NainaCricket24
PriyaCricket25

EXCEPT with LIKE Operator

The LIKE operator is used to perform pattern matching on a string. The EXCEPT operator can also be used with the LIKE operator in SQL to exclude rows that matches with the specified pattern.

Example

In here, we are retrieving records from the STUDENTS table where the values in the HOBBY column starts with ‘F’, while excluding similar rows from the STUDENTS_HOBBY table −

SELECT ID, NAME, HOBBY, AGE FROM STUDENTS
WHERE HOBBY LIKE'F%'EXCEPTSELECT ID, NAME, HOBBY, AGE FROM STUDENTS_HOBBY
WHERE HOBBY LIKE'F%';

Output

The output for the above query is produced as given below −

IDNAMEHOBBYAGE
6KalyanFootball30

Comments

Leave a Reply

Your email address will not be published. Required fields are marked *