[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;