전체/Oracle
DECODE문의 두가지 유형
effortDev
2017. 7. 21. 10:37
DECODE문은 두가지 유형으로 사용된다.
'조건', 'IF', TRUE, FALSE
'조건', 'IF1', TRUE, 'IF2', TRUE ,'IF3' TRUE
1 2 3 4 5 6 7 | SELECT DECODE('조건2', '조건1', '결과1' , '조건2', DECODE('조건2-1','조건2-2','결과2-1','결과2-2') , '조건3', '결과3') FROM DUAL -- 다음 DECODE문을 보면 IF1 TRUE1, IF2 TRUE2, IF3 TRUE3이 적용된것이고 -- 조건2로 DECODE문을 보면 IF TRUE FALSE로 조건이 맞지 않아 FALSE로 접근한 것을 알 수 있다. | cs |
실행결과
결과 2-2 가 나오는것을 확인할 수 있다.
DECODE문은 NVL과 NVL2의 문법형식을 합쳐놓은 것이라 생각하면 이해하기 쉽다.
1 2 3 | SELECT NVL('컬럼값이NULL일때','TRUE') , NVL2('컬럼값이NULL일때','TRUE','FALSE') FROM DUAL | cs |
CASE문과 비슷하지만 DECODE문은 더 복잡한 분기처리와 쿼리양을 줄일수 있다고 생각한다.