Database/SQL

Oracle 오라클 CASE문 사용법 CASE WHEN THEN END

리커니 2013. 5. 24.
반응형

 

ORACLE 오라클 CASE문 사용법 CASE WHEN THEN END

 

 

* CASE 문의 사용법

CASE문은 여타 다른 프로그래밍 언어들과 같이 조건이나 값에 해당하는 결과값을 RETURN하는데 사용한다.

CASE문에는 사용법은 같지만 조건이 다른 2가지 방식이 존재한다. 값에 따라 결과값을 RETURN하는 방식과 조건에 따라 결과값을 RETURN하는 방식이 그것이다.

첫번째 방식부터 알아보도록 하자.

 

CASE 대상값 WHEN 값1 THEN 결과1
            WHEN 값2 THEN 결과2
                        .
                        .
                        .
            WHEN 값n THEN 결과m END;

 

위의 용법과 같이 대상값이 값1에 해당하면 결과2를..값n에 해당하면 결과m을 출력한다.

*예제1

위와 같은 사원테이블이 있다. 이중 주민번호(RRN_NO)의 7번째 숫자를 가지고 성별을 출력하는 SELECT문을 보도록하자.

 

SELECT T1.EMP_NM
     , CASE SUBSTR(T1.RRN_NO, 7, 1) WHEN '1' THEN '남자'
                                    WHEN '2' THEN '여자' END AS GENDER
 FROM AMT_MST_TEST T1

 

주민번호(RRN_NO)의 7번째자리(SUBSTR(T1.RRN_NO, 7, 1))이 '1' 이라면 '남자' 를 '2'라면 '여자' 를 GENDER라면 별칭을 주어 출력하였다.

두번째 방식에 대해서 알아보자.

 

CASE WHEN 조건1 THEN 결과1
     WHEN 조건2 THEN 결과2
                .
                .
                .
     WHEN 조건n THEN 결과m END;

 

조건n에 해당되면 결과m을 출력한다.

 

*예제2

예제1과 같은 테이블을 사용하여 입사년차별 진급대상자를 출력.

입사년차가 5년이상이라면 [과장]진급예정자, 3년차이상이라면 [대리]진급예정자, 1년차이상이라면 [주임]진급예정자 1년도 안되었다면 [진급대상아님]을 을 출력하는 SELECT문을 보도록 하자.

 

SELECT T1.EMP_NM
     , TO_NUMBER(TO_CHAR(SYSDATE, 'YYYY')) - TO_NUMBER(SUBSTR(JOIN_DT, 1, 4)) AS PERIOD
     , CASE WHEN TO_NUMBER(TO_CHAR(SYSDATE, 'YYYY')) 
               - TO_NUMBER(SUBSTR(T1.JOIN_DT, 1, 4)) >= 5 THEN '[과장]급예정자'
            WHEN TO_NUMBER(TO_CHAR(SYSDATE, 'YYYY')) 
               - TO_NUMBER(SUBSTR(T1.JOIN_DT, 1, 4)) >= 3 THEN '[대리]진급예정자'
            WHEN TO_NUMBER(TO_CHAR(SYSDATE, 'YYYY')) 
               - TO_NUMBER(SUBSTR(T1.JOIN_DT, 1, 4)) >= 1 THEN '[주임]진급예정자'
            ELSE '[진급대상아님]'  END UP_POSI
  FROM AMT_MST_TEST T1

 

위의 CASE문을 보면 TO_NUMBER(TO_CHAR(SYSDATE, 'YYYY'))는 현재년도를 구한 것이고 계산을 위해 TO_NUMBER를 사용하였습니다. 거기에 TO_NUMBER(SUBSTR(T1.JOIN_DT, 1, 4)) 입사일자의 년도만 빼내어 계산을 합니다.(PERIOD)

그럼 위와 같이 조건별 결과값이 출력되게 됩니다.

 

PS. CASE문은 활용빈도가 높습니다.

반응형

댓글

💲 추천 글