본문으로 바로가기

[Oracle] sysdate와 systimestamp 정리 및 예제

category 4. Database/4_3 Oracle 기본 2018. 10. 4. 23:40
반응형

[Oracle] sysdate와 systimestamp 정리 및 예제


안녕하세요. 갓대희 입니다. 이번 포스팅은 [ [오라클] sysdate, systimestamp 정리 ] 입니다. : ) 


자바 웹 개발을 하다보면 밀리세컨즈 까지 시간단위를 가져와 활용할 때가 있다.

그럼 오라클에서 밀리세컨드까지 시간단위를 가져올 수 있는 방법도 정리 해보려 한다.


sysdate

1. sysdate의 경우 년월일시분초 까지 표현 가능

ex) select sysdate from dual;

2. SYSDATE 활용
 - 날짜를 포맷 적용하여 문자열로 변환


1번 2번 같은 결과
/* 1. 결과 2018-10-04 10:49:52 */
select to_char(sysdate, 'YYYY-MM-DD HH:MI:SS') from dual; 
/* 2. 결과 2018-10-04 10:49:52 */
select to_char(sysdate, 'yyyy-mm-dd hh:mi:ss') from dual;


3번 4번 같은 결과
/* 3. 결과 2018/10/04 22:49:52 */
select to_char(sysdate, 'YYYY/MM/DD HH24:MI:SS') from dual;
/* 4. 결과 2018/10/04 22:49:52 */
select to_char(sysdate, 'yyyy/mm/dd hh24:mi:ss') from dual;


/* 5. 일자만 가져오고 싶을때*/
select to_char(sysdate, 'yyyy-mm-dd') from dual;


3.TO_DATE 활용
 - 문자열을 포맷 적용하여 날짜로 변환
 - 날짜형식을 문자열로 바꿀땐 좀더 엄격하다.
/* 1. 결과 : 오류 ORA-01849: hour must be between 1 and 12
   시간 은 1 에서 12 사이 어야 합니다
   포맷이 HH24가 아닌 HH인경우 12까지밖에 지원하지 않는다. */
select to_date('2018-10-04 22:49:52','YYYY-MM-DD HH:MI:SS') from dual;


/* 2. 결과 2018-10-04 22:49:52 */
select to_date('2018-10-04 22:49:52','YYYY-MM-DD HH24:MI:SS') from dual;


/* 3. 결과 : 오류 ORA-01830: date format picture ends before converting entire input string 
  날짜 형식의 지정에 불필요한 데이터가 포함되어 있습니다.
  포맷과 맞지 않는 날짜 형식이 포함되어있으면 오류 */
select to_date('2018-10-04 22:49:52','YYYY-MM-DD') from dual;

/* 4. 결과 2018-10-04 00:00:00 */
select to_date('2018-10-04','YYYY-MM-DD HH24:MI:SS') from dual;


/* 5. 결과 : 오류 ORA-01858: a non-numeric character was found where a numeric was expected
   숫자가 있어야 하는 위치에서 숫자가 아닌 문자가 발견되었습니다.
   :이 문제 HH24MISS => HH24:MI:SS로 변경하거나 22:49:53를 224952로 변경하면 정상출력 */
select to_date('20181004 22:49:52','YYYYMMDD HH24MISS') from dual;


/* 4. 결과 20181004 224952 */
select to_date('20181004 224952','YYYYMMDD HH24MISS') from dual;



3.ETC
/* 1. + 를 통해 1일 더하기 (- : 빼기) */
/* 결과 : 2018-10-05 오후 10:49:52 */
select to_date('2018-10-04 22:49:52','YYYY-MM-DD HH24:MI:SS') + 1 from dual;
SELECT SYSDATE + 1 FROM DUAL;


/* 2. + 1초 ( 1/24/60/60 ) */
/* 결과 : 2018-10-04 00:00:01  */
select to_date('2018-10-04 00:00:00','YYYY-MM-DD HH24:MI:SS') + 1/24/60/60 from dual;


/* 3. 응용하여 1시간, 1분 도 충분히 가능 */
/* 결과 : 2018-10-04 00:01:00  */  
select to_date('2018-10-04 00:00:00','YYYY-MM-DD HH24:MI:SS') + 1/24/60 from dual;
/* 결과 : 2018-10-04 01:00:00  */
select to_date('2018-10-04 00:00:00','YYYY-MM-DD HH24:MI:SS') + 1/24 from dual;


/* 4. 혹시 자바 개발자는 날짜변환할때 오라클때문에 갑자기 헷갈릴 수 있다.*/
오라클에선 2018-10-04(오늘 현재 날짜)를 가져 오기 위해서 다음과 같이 포맷 작성. 
select to_char(sysdate, 'yyyy-mm-dd') from dual;


java에선 다음과 같이 해버린다면 큰일 난다. 
SimpleDateFormat test = new SimpleDateFormat("yyyy-mm-dd");
test에 2018-10-04 가 들어오지 않고 2018-49-04 라는 전혀 엉뚱한 숫자가 들어온다.


날짜 포맷을 yyyy-mm-dd => yyyy-MM-dd 즉 mm을 대문자로 작성해주자
SimpleDateFormat test = new SimpleDateFormat("yyyy-MM-dd");


systimestamp


 - systimestamp의 경우 년월일시분초 밀리세컨드 까지 표현 가능


 ※ 밀리세컨즈까지 저장하려면 해당 컬럼의 데이터 타입을 timestamp로 지정해야 한다.


 ex) select systimestamp from dual;

날짜에 포맷을 적용해 문자열로 변환할 때
/* 결과 : 2018-10-04 11:21:22:923000*/
select to_char(systimestamp, 'YYYY-MM-DD HH:MI:SS:FF') from dual;


여기서 FF는 밀리세컨드를 의미한다.
FF뒤에 숫자를 붙여 추가할 밀리세컨드 자리수를 지정할 수 있다.


/* 결과 : 2018-10-04 11:21:22:9*/
select to_char(systimestamp, 'YYYY-MM-DD HH:MI:SS:FF1') from dual;
/* 결과 : 2018-10-04 11:21:22:92*/
select to_char(systimestamp, 'YYYY-MM-DD HH:MI:SS:FF2') from dual;
/* 결과 : 2018-10-04 11:21:22:923000*/
select to_char(systimestamp, 'YYYY-MM-DD HH:MI:SS:FF6') from dual;


반응형

댓글을 달아 주세요