3. Database/Oracle 기본
[Oracle] sysdate와 systimestamp 정리 및 예제
갓대희
2018. 10. 4. 23:40
728x90
[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;
300x250