[Oracle] 오라클 날짜를 계산하는 다양한 방법 (연산자, 함수)
- DB/Oracle
- 2019. 12. 1.
날짜 계산 (연산자)
SELECT
SYSDATE + 100, --현재날짜 +100일
SYSDATE - 100, --현재날짜 -100일
SYSTIMESTAMP + 100, --현재날짜 +100일
SYSTIMESTAMP - 100 --현재날짜 -100일
FROM
DUAL
위와같이 + , - 연산자를 활용하여 간단한 날짜 계산이 가능합니다.
날짜 계산 (함수)
SELECT
ADD_MONTHS(SYSDATE,6), --현재시간 + 6개월 뒤
LAST_DAY(SYSDATE), --해당월 마지막 일자 계산
NEXT_DAY(SYSDATE,'일요일'), --다음 주 일요일 계산
MONTHS_BETWEEN(SYSDATE, SYSDATE-100) --DATE1과 DATE2의 개월 수 반환
FROM
DUAL
- ADD_MONTHS(date, integer) : ADD_MONTHS함수는 매개변수 DATE에 매개변수 INTEGER만큼의 월을 더한 날짜를 리턴합니다.
- LAST_DATE(date) : LASTE_DAY함수는 현재 월의 마지막 일자를 리턴합니다.
- NEXT_DAY(date, char) : NEXT_DAY함수는 매개변수 date의 다음 주 char(요일)의 날짜를 리턴합니다.
- MONTHS_BETWEEN(date1, date2) : MONTHS_BETWEEN함수는 매개변수 date1과 date2 사이의 개월수를 리턴합니다.
다양한 날짜 계산 EXAMPLE
SELECT
TO_CHAR(SYSDATE ,'yyyy/mm/dd'), --오늘 날짜
TO_CHAR(SYSDATE + 1 ,'yyyy/mm/dd'), --내일 날짜
TO_CHAR(SYSDATE -1 ,'yyyy/mm/dd'), --어제 날짜
TO_CHAR(TRUNC(SYSDATE,'dd') ,'yyyy/mm/dd hh24:mi:ss'), -- 오늘 정각 날짜
TO_CHAR(TRUNC(SYSDATE,'dd') + 1,'yyyy/mm/dd hh24:mi:ss'), -- 내일 정각 날짜
TO_CHAR(SYSDATE + 1/24/60/60 ,'yyyy/mm/dd hh24:mi:ss'), -- 1초 뒤 시간
TO_CHAR(SYSDATE + 1/24/60 ,'yyyy/mm/dd hh24:mi:ss'), -- 1분 뒤 시간
TO_CHAR(SYSDATE + 1/24 ,'yyyy/mm/dd hh24:mi:ss'), -- 1일 뒤 시간
TO_CHAR(TRUNC(SYSDATE,'mm') ,'yyyy/mm/dd'), --이번 달 시작날짜
TO_CHAR(LAST_DAY(SYSDATE) ,'yyyy/mm/dd'), --이번 달 마지막 날
TO_CHAR(trunc(ADD_MONTHS(SYSDATE, + 1),'mm') ,'yyyy/mm/dd'), --다음 달 시작날짜
TO_CHAR(ADD_MONTHS(SYSDATE, 1) ,'yyyy/mm/dd hh24:mi:ss'), -- 다음달 오늘 날자
TO_CHAR(TRUNC(SYSDATE, 'yyyy') ,'yyyy/mm/dd'), --올해 시작 일
TO_CHAR(TRUNC(ADD_MONTHS(SYSDATE, -12), 'dd'),'yyyy/mm/dd'), --작년 현재 일
TO_DATE(TO_CHAR(SYSDATE, 'YYYYMMDD')) - TO_DATE('19930315'), -- 두 날짜 사이 일수 계산
MONTHS_BETWEEN(SYSDATE, '19930315'), -- 두 날짜 사이의 월수 계산
TRUNC(MONTHS_BETWEEN(SYSDATE, '19930315')/12,0) --두 날짜 사이의 년수 계산
FROM
DUAL;
'DB > Oracle' 카테고리의 다른 글
[Oracle] 오라클 첫번째 NULL값의 다음 값 찾기 COALESCE 함수 사용법 (11) | 2019.12.03 |
---|---|
[Oracle] 오라클에서 날짜를 비교하는 방법 (2) | 2019.12.02 |
[Oracle] 오라클 다양한 날짜 / 시간 포맷 변경 (TO_CHAR) 사용법 & 예제 (0) | 2019.11.30 |
[Oracle] 현재날짜 / 현재시간을 나타내는 (SYSDATE, SYSTIMESTAMP 함수) (0) | 2019.11.29 |