Oracle DECODE() function compares the first argument with the second argument. If they are equal, the function returns the third argument otherwise returns the default value.
The Oracle/PLSQL DECODE function has the functionality of an IF-THEN-ELSE statement:
SELECT DECODE (1, 1, 'ONE', 'TWO') FROM DUAL;
data:image/s3,"s3://crabby-images/db765/db765d3d1ca178011e88b0502bc6082fc8a13bea" alt=""
- Decode works like the following if statement:
BEGIN
IF 1 = 1
THEN
DBMS_OUTPUT.put_line ('one');
ELSE
DBMS_OUTPUT.put_line ('two');
END IF;
END;
data:image/s3,"s3://crabby-images/78d71/78d71ff061100b656a04607517233ef075519871" alt=""
- If you want to specify a default value when the first argument is not equal to the second one, the default value to the argument list as shown below:
SELECT DECODE (1, 2, 'ONE', 'TWO') FROM DUAL;
Result: TWO
- This example also works like an if-else statement:
BEGIN
IF 1 = 2
THEN
DBMS_OUTPUT.put_line ('one');
ELSE
DBMS_OUTPUT.put_line ('two');
END IF;
END;
Result: TWO