전체/Oracle

ORACLE 날짜 함수(MONTHS_BETWEEN, ADD_MONTHS, NEXT_DAY, LAST_DAY, TO_DATE) 활용, DECODE, CASE 문 사용

effortDev 2017. 6. 12. 18:04


1. MONTHS_BETWEEN


달수와 달수 사이를 구한다.



1
2
3
4
5
6
7
-- MONTHS_BETWEEN
SELECT MONTHS_BETWEEN
       (
       TO_DATE('2017-07-01','YYYY-MM-DD')
     , TO_DATE('2017-06-01','YYYY-MM-DD')
       ) AS MONTHS_BETWEEN
  FROM DUAL
cs

출력 결과




2. ADD_MONTHS


달수를 더한다.



1
2
3
-- ADD_MONTHS
SELECT ADD_MONTHS(TO_DATE('2017-07-01','YYYY-MM-DD'),1) AS ADD_MONTHS
  FROM DUAL
cs


출력 결과




3. NEXT_DAY


기준날짜에서 요일을 찾아 몇일인지 반환한다.



1
2
3
-- NEXT_DAY
SELECT NEXT_DAY(TO_DATE('2017-06-05','YYYY-MM-DD'),'FRIDAY'
  FROM DUAL
cs


출력 결과




4. LAST_DAY


기준날짜에서 마지막 날을 출력한다.



1
2
3
-- LAST_DAY
SELECT LAST_DAY(TO_DATE('2017-06-01','YYYY-MM-DD'))
  FROM DUAL
cs


출력 결과




5. TO_DATE


DATE 형식으로 출력한다.



1
2
3
4
5
6
7
8
9
10
11
12
-- TO_DATE1
SELECT TO_DATE('2017-06-01','YYYY-MM-DD') MDATE1
     , TO_DATE('2017/06/01','YYYY/MM/DD') MDATE2
     , TO_DATE('20170601','YYYY-MM-DD') MDATE3
     , TO_DATE('20170601','YYYYMMDD') MDATE4
     , TO_DATE('20170601112030','YYYYMMDDHH12MISS') MDATE5
     , TO_DATE('20170601232030','YYYYMMDDHH24MISS') MDATE6
     , TO_DATE('2017-06-01-11-20-30','YYYY-MM-DD-HH12-MI-SS') MDATE7
     , TO_DATE('2017-06-01-23-20-30','YYYY-MM-DD-HH24-MI-SS') MDATE8
     , TO_DATE('2017/06/01/11/20/30','YYYY/MM/DD/HH12/MI/SS') MDATE9
     , TO_DATE('2017/06/01/23/20/30','YYYY/MM/DD/HH24/MI/SS') MDATE10
  FROM DUAL
cs

출력 결과



1
2
3
4
5
6
7
8
9
10
11
12
13
-- TO_DATE2
SELECT TO_DATE(SYSDATE,'YYYY-MM-DD') MDATE1
     , SYSDATE MDATE2
     , TO_CHAR(SYSDATE) MDATE3
     , TO_CHAR(SYSDATE,'YYYY-MM-DD') MDATE4
     , TO_CHAR(SYSDATE,'YYYY/MM/DD') MDATE5
     , TO_DATE(TO_CHAR(SYSDATE,'YYYY-MM-DD'),'YYYY-MM-DD') MDATE6
     , TO_DATE(TO_CHAR(SYSDATE,'YYYY/MM/DD'),'YYYY/MM/DD') MDATE7
     , TO_CHAR(SYSDATE,'YYYY-MM') MDATE8
     , TO_CHAR(SYSDATE,'YYYY/MM') MDATE9
     , TO_CHAR(SYSDATE,'MM') MDATE10
     , TO_CHAR(SYSDATE,'DD') MDATE11
  FROM DUAL
cs


출력 결과




6. DECODE


DECODE(VALUE, IF1, THEN1, IF2, THEN2)


DECODE 함수는 조건에 따라 데이터를 다른 값이나 컬럼값으로 추출 할 수 있다.

DECODE(VALUE, IF1, THEN1, IF2, THEN2...) 형태로 사용 할 수 있다.

VALUE 값이 IF1일 경우에 THEN1 값을 반환하고, VALUE 값이 IF2일 경우에는 THEN2 값을 반환한다.

DECODE 함수 안에 DECODE함수를 중첩으로 사용 할 수 있다.



1
2
3
4
SELECT DEPTNO
     , DECODE(DEPTNO, 10'CLERK',20'MANAGER',30'SALESMAN') AS DECODE
     , DECODE(DEPTNO, 10, SAL)
  FROM EMP;
cs


출력 결과




7. CASE


CASE 

 WHEN 

 THEN 

 ELSE 

END 컬럼명


CASE 함수는 DECODE함수가 제공하지 못하는 비교연산의 단점을 해결할 수 있는 함수이다.

DECODE함수에서 비교연산을 수행하기 위해서는 GREATEST, LEAST등의 함수를 사용해야 하지만, CASE함수에서는 조건 연산자를 모두 사용 할 수 있다.

CASE함수는 IF.. THEN .. ELSE 구문과 비슷 하다. WHEN절 다음에 여러 조건이 올 수 있다.



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
SELECT JOB
     , CASE
        WHEN JOB='CLERK'
        THEN 'MY_CLERK'
       END JOB1
     , SAL
     , CASE 
        WHEN SAL<1000
        THEN SAL+200
       END SAL1
     , HIREDATE
     , CASE
        WHEN HIREDATE<TO_DATE('1981-03-01','YYYY-MM-DD')
        THEN ADD_MONTHS(HIREDATE,1)
       END HIREDATE1
  FROM EMP
cs


출력 결과