How to use a CASE statement in SQL

How to use a CASE statement in SQL

2 mins read864 Views Comment
Updated on Nov 22, 2022 19:35 IST

In SQL you can apply conditions on the cell based on other cells using CASE statement. In this article we will discuss how to use a case statement in sql in different scenarios.

2022_07_SQL-CASE.jpg

Table of Content

Recommended online courses

Best-suited Data Analytics courses for you

Learn Data Analytics with these high-rated online courses

What is a SQL CASE statement?

SQL CASE statement is similar to the IF-THEN-ELSE statement of any other programming language that returns the result after evaluating conditions. If none of the conditions is evaluated to TRUE, it will return the condition given in the ELSE block.

Syntax

 
CASE
WHEN condition_1 THEN value_1
WHEN condition_2 THEN value_2
WHEN condition_n THEN value_n
ELSE value
END
Copy code

Points to Remember:

  • CASE statement must be followed by at least one WHEN-THEN statement
  • ELSE argument is optional
  • NULL value can’t be checked using CASE statement

Now, let’s move to some examples to get a better understanding of how to use a CASE statement in SQL.

We will start with a simple example.

Must Read: Introduction to SQL

Must Read: SQL ACID Properties

Example -1: Below table (Student) contains the marks of ten students, using a case statement give each student a grade.

Student ID Name Percentage
1001 Ajay 87
1002 Babloo 81
1003 Chhavi 79
1004 Dheeraj 93
1005 Evina 95
1006 Fredy 80.7
1007 Garima 63
1008 Hans 49
1009 Ivanka 88
1010 Jai 74
Student

Now, we will define grade for each students using CASE statement.

Query

 
SELECT *
CASE
WHEN Percentage > 90 THEN ‘O’
WHEN Percentage > 80 AND Percentage <= 90 THEN ‘A’
WHEN Percentage > 70 AND Percentage <= 80 THEN ‘B’
WHEN Percentage > 60 AND Percentage <= 70 THEN ‘C’
WHEN Percentage > 50 AND Percentage <= 60 THEN ‘D’
ELSE ‘Fail’
END AS Grade,
FROM Student;
Copy code

Output

Student ID Name Percentage Grade
1001 Ajay 87 A
1002 Babloo 81 A
1003 Chhavi 79 B
1004 Dheeraj 93 O
1005 Evina 95 O
1006 Fredy 80.7 A
1007 Garima 63 C
1008 Hans 49 F
1009 Ivanka 88 A
1010 Jai 74 B

Must Read: What is the difference between SQL and MySQL?

Must Read: Difference between SQL and NoSQL

CASE with GROUP BY

Example 2: Using the above Student data, classify the students in to Pass or Fail and count the number of student in both the category.

Query

 
SELECT
CASE
WHEN Percentage > 50 THEN ‘PASS’
ELSE ‘FAIL’
END AS Category,
COUNT (*) AS Total _number_of_students
FROM Student
GROUP BY Grade;
Copy code

Output

Category Total _number_of_students
PASS 9
FAIL 1

Must Read: Subqueries in SQL

Must Read: SQL CREATE TABLE

ORDER BY with CASE

Example 3: Sort the result of example 1 in Descending order i.e. sort the student marks such that highest grades are on top?

Query

 
SELECT Name
CASE
WHEN Percentage > 90 THEN ‘O’
WHEN Percentage > 80 AND Percentage <= 90 THEN ‘A’
WHEN Percentage > 70 AND Percentage <= 80 THEN ‘B’
WHEN Percentage > 60 AND Percentage <= 70 THEN ‘C’
WHEN Percentage > 50 AND Percentage <= 60 THEN ‘D’
ELSE ‘Fail’
END AS Grade,
FROM Student
ORDER BY Percentage DESC;
Copy code

Output

Name Grade
Evina O
Dheeraj O
Ivanka A
Ajay A
Babloo A
Fredy A
Chhavi B
Jai B
Garima C
Hans F

Now, in the next example we will use GROUP BY, ORDER BY and COUNT together

Must Read: SQL WHERE

Must Read: Introduction to Normalization

Example 4: Find the number of student in each grade.

Query

 
SELECT
CASE
WHEN Percentage > 90 THEN ‘O’
WHEN Percentage > 80 AND Percentage <= 90 THEN ‘A’
WHEN Percentage > 70 AND Percentage <= 80 THEN ‘B’
WHEN Percentage > 60 AND Percentage <= 70 THEN ‘C’
WHEN Percentage > 50 AND Percentage <= 60 THEN ‘D’
ELSE ‘Fail’
END AS Grade,
COUNT(*) AS Total Student
FROM Student
GROUP BY Grade
ORDER BY Percentage DESC;
Copy code

Output

Grade Total Student
O 2
A 4
B 2
C 1
D 0
F 1

Must Read: SQL LIMITS

Must Check: SQL Online Course and Certifications

Conclusion

In this article, we have discussed how to use a CASE statement in SQL with the help of examples.

Hope this article, will help you in your Data Science/Data Analysis journey.

About the Author