티스토리 뷰

Skill/DB

oracle systimestamp

진열사랑 2022. 1. 18. 10:35

출처:https://goddaehee.tistory.com/m/155

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;


'Skill > DB' 카테고리의 다른 글

where절에 if문처럼 and조건 사용하기  (0) 2022.01.19
oracle lock 조회 및 해제  (0) 2022.01.19
오라클 테이블 정보 확인  (0) 2021.12.20
ORANGE ORACLE 단축키  (0) 2021.12.20
[tibero] Tibero Admin tool로 테이블 내려받기  (0) 2021.03.17
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/11   »
1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
글 보관함