Member-only story
DECODE vs CASE IN ORACLE
While working on one of the projects got a chance to explore DECODE and CASE STATEMENT in Oracle Database.
data:image/s3,"s3://crabby-images/e565a/e565a97bffe41622c72771cfb9d68a186d71dc24" alt=""
DECODE: Decode is an function in sql.It's a way of converting a written code into understandable language.
CASE: Case are the statement in sql.It's a way of responding to the occurrence of a value or what action to be performed when a particular value occurs.
DIFFERENCES
data:image/s3,"s3://crabby-images/7aaf1/7aaf1224942bd1ad8b83c7d708b4f587bdedc5d0" alt=""
SYNTAX
Consider an table called employee with some data.
data:image/s3,"s3://crabby-images/695ac/695ac45fe7abb66e4926542ff721d086e7939573" alt=""
Example: Write an SQL to fetch id, name and if is_new is 1 then “‘NEW EMPLOYEE’ else ‘OLD EMPLOYEE’.
Solution:
Using CASE STATEMENT
select id , name ,
case
when is_new=1 then ‘NEW EMPLOYEE’
when is_new=2 then ‘OLD EMPLOYEE’
END as is_new
from employee;
data:image/s3,"s3://crabby-images/d8f64/d8f647ef01e6bc02c12c03fb9dd663373878dce0" alt=""
Using DECODE
select id , name,
DECODE(is_new, 1, ‘NEW EMPLOYEE’, 2 , ‘OLD EMPLOYEE’) as is_new
from employee;
data:image/s3,"s3://crabby-images/e53ac/e53ac548562ae2ed57d9977c9e12f08c3558c49c" alt=""
Thanks for the read🙂. Do clap if you find it useful👏.
“Keep learning and keep sharing knowledge”