PL / SQL-날짜 및 시간

이 장에서는 PL / SQL의 날짜와 시간에 대해 설명합니다. PL / SQL에는 두 가지 종류의 날짜 및 시간 관련 데이터 유형이 있습니다.

  • Datetime 데이터 유형
  • 간격 데이터 유형

Datetime 데이터 유형은-

  • DATE
  • TIMESTAMP
  • 시간대가있는 타임 스탬프
  • 현지 시간대가있는 타임 스탬프

간격 데이터 유형은-

  • INTERVAL YEAR TO MONTH
  • INTERVAL DAY TO SECOND

Datetime 및 Interval 데이터 유형에 대한 필드 값

양자 모두 datetimeinterval 데이터 유형은 다음으로 구성됩니다. fields. 이 필드의 값은 데이터 유형의 값을 결정합니다. 다음 표에는 날짜 시간 및 간격에 대한 필드와 가능한 값이 나열되어 있습니다.

분야 명 유효한 날짜 / 시간 값 유효한 간격 값
-4712 ~ 9999 (0 년 제외) 0이 아닌 정수
01에서 12 0에서 11
01 ~ 31 (로케일의 달력 규칙에 따라 MONTH 및 YEAR 값으로 제한됨) 0이 아닌 정수
00에서 23 0에서 23
00에서 59 0에서 59
둘째

00 ~ 59.9 (n), 여기서 9 (n)은 시간 분수 초의 정밀도입니다.

9 (n) 부분은 DATE에 적용되지 않습니다.

0 ~ 59.9 (n), 여기서 9 (n)은 간격 소수 초의 정밀도입니다.
TIMEZONE_HOUR

-12 ~ 14 (범위는 일광 절약 시간 변경을 수용 함)

DATE 또는 TIMESTAMP에는 적용되지 않습니다.

해당 없음
TIMEZONE_MINUTE

00에서 59

DATE 또는 TIMESTAMP에는 적용되지 않습니다.

해당 없음
TIMEZONE_REGION DATE 또는 TIMESTAMP에는 적용되지 않습니다. 해당 없음
TIMEZONE_ABBR DATE 또는 TIMESTAMP에는 적용되지 않습니다. 해당 없음

Datetime 데이터 유형 및 함수

다음은 Datetime 데이터 유형입니다-

데이트

문자 및 숫자 데이터 유형 모두에 날짜 및 시간 정보를 저장합니다. 세기, 년, 월, 날짜,시, 분, 초에 대한 정보로 구성됩니다. 다음과 같이 지정됩니다.

타임 스탬프

DATE 데이터 유형의 확장입니다. 시간, 분, 초 값과 함께 DATE 데이터 유형의 년, 월, 일을 저장합니다. 정확한 시간 값을 저장하는 데 유용합니다.

시간대가있는 타임 스탬프

시간대 지역 이름 또는 해당 값에 시간대 오프셋을 포함하는 TIMESTAMP의 변형입니다. 시간대 오프셋은 현지 시간과 UTC의 차이 (시간 및 분)입니다. 이 데이터 유형은 여러 지역에서 날짜 정보를 수집하고 평가하는 데 유용합니다.

현지 시간대가있는 타임 스탬프

값에 시간대 오프셋을 포함하는 TIMESTAMP의 또 다른 변형입니다.

다음 표는 Datetime 함수를 제공합니다 (여기서 x는 datetime 값을 가짐)-

S. 아니 기능 이름 및 설명
1

ADD_MONTHS(x, y);

추가 y 개월 ~ x.

2

LAST_DAY(x);

해당 월의 마지막 날을 반환합니다.

MONTHS_BETWEEN(x, y);

개월 수를 반환합니다. xy.

4

NEXT_DAY(x, day);

다음의 날짜 반환 후를x.

5

NEW_TIME;

사용자가 지정한 시간대에서 시간 / 일 값을 반환합니다.

6

ROUND(x [, unit]);

라운드 x.

7

SYSDATE();

현재 날짜 시간을 반환합니다.

8

TRUNC(x [, unit]);

잘림 x.

타임 스탬프 함수 (여기서 x는 타임 스탬프 값을 가짐) −

S. 아니 기능 이름 및 설명
1

CURRENT_TIMESTAMP();

세션 시간대와 함께 현재 세션 시간을 포함하는 TIMESTAMP WITH TIME ZONE을 리턴합니다.

2

EXTRACT({ YEAR | MONTH | DAY | HOUR | MINUTE | SECOND } | { TIMEZONE_HOUR | TIMEZONE_MINUTE } | { TIMEZONE_REGION | } TIMEZONE_ABBR ) FROM x)

에서 년, 월, 일,시, 분, 초 또는 표준 시간대를 추출하고 반환합니다. x.

FROM_TZ(x, time_zone);

TIMESTAMP x 및 time_zone으로 지정된 시간대를 TIMESTAMP WITH TIMEZONE으로 변환합니다.

4

LOCALTIMESTAMP();

세션 시간대의 현지 시간을 포함하는 TIMESTAMP를 리턴합니다.

5

SYSTIMESTAMP();

데이터베이스 시간대와 함께 현재 데이터베이스 시간을 포함하는 TIMESTAMP WITH TIME ZONE을 리턴합니다.

6

SYS_EXTRACT_UTC(x);

TIMESTAMP WITH TIMEZONE x를 날짜 및 시간 (UTC)을 포함하는 TIMESTAMP로 변환합니다.

7

TO_TIMESTAMP(x, [format]);

문자열 x를 TIMESTAMP로 변환합니다.

8

TO_TIMESTAMP_TZ(x, [format]);

문자열 x를 TIMESTAMP WITH TIMEZONE으로 변환합니다.

다음 코드 스 니펫은 위 함수의 사용을 보여줍니다.

Example 1

SELECT SYSDATE FROM DUAL;

Output

08/31/2012 5:25:34 PM

Example 2

SELECT TO_CHAR(CURRENT_DATE, 'DD-MM-YYYY HH:MI:SS') FROM DUAL;

Output

31-08-2012 05:26:14

Example 3

SELECT ADD_MONTHS(SYSDATE, 5) FROM DUAL;

Output

01/31/2013 5:26:31 PM

Example 4

SELECT LOCALTIMESTAMP FROM DUAL;

Output

8/31/2012 5:26:55.347000 PM

간격 데이터 유형 및 함수

다음은 간격 데이터 유형입니다-

  • IINTERVAL YEAR TO MONTH-YEAR 및 MONTH datetime 필드를 사용하여 기간을 저장합니다.

  • INTERVAL DAY TO SECOND-일, 시간, 분, 초 단위로 일정 기간을 저장합니다.

간격 함수

S. 아니 기능 이름 및 설명
1

NUMTODSINTERVAL(x, interval_unit);

숫자 x를 INTERVAL DAY TO SECOND로 변환합니다.

2

NUMTOYMINTERVAL(x, interval_unit);

숫자 x를 INTERVAL YEAR TO MONTH로 변환합니다.

TO_DSINTERVAL(x);

문자열 x를 INTERVAL DAY TO SECOND로 변환합니다.

4

TO_YMINTERVAL(x);

문자열 x를 INTERVAL YEAR TO MONTH로 변환합니다.