날짜/시간 함수와 연산자

ADDDATE, DATE_ADD

ADDDATE(date, INTERVAL expr unit)
ADDDATE(date, days)
DATE_ADD(date, INTERVAL expr unit)

ADDDATE 함수와 DATE_ADD 함수는 동일하며, 특정 DATE 값에 대해 덧셈 또는 뺄셈을 실행한다. 리턴 값은 DATE 타입 또는 DATETIME 타입이다. DATETIME 타입을 반환하는 경우는 다음과 같다.

  • 첫 번째 인자가 DATETIME 타입 또는 TIMESTAMP 타입인 경우

  • 첫 번째 인자가 DATE 타입이고 INTERVAL 값의 단위가 날짜 단위 미만으로 지정된 경우

위의 경우 외에 DATETIME 타입의 결과 값을 반환하려면 CAST() 함수를 이용하여 첫 번째 인자 값의 타입을 변환해야 한다. 연산 결과의 날짜가 해당 월의 마지막 날짜를 초과하면, 해당 월의 말일을 적용하여 유효한 DATE 값을 반환한다.

입력 인자의 날짜와 시간 값이 모두 0이면 시스템 파라미터 return_null_on_function_errors 의 값에 따라 다른 값을 반환한다. return_null_on_function_errors 가 yes이면 NULL 을 반환하고 no이면 에러를 반환하며, 기본값은 no 이다.

계산 결과가 ‘0000-00-00 00:00:00’과 ‘0001-01-01 00:00:00’ 사이이면, 날짜와 시간 값이 모두 0인 DATE 또는 DATETIME 타입의 값을 반환한다. 그러나 JDBC 프로그램에서는 연결 URL 속성인 zeroDateTimeBehavior의 설정에 따라 동작이 달라진다. JDBC의 연결 URL 속성은 연결 설정 을 참고하면 된다.

Parameters:
  • dateDATE, DATETIME 또는 TIMESTAMP 타입의 연산식이며, 시작 날짜를 의미한다. 만약, ‘2006-07-00’와 같이 유효하지 않은 DATE 값이 지정되면, 에러를 반환한다.

  • expr – 시작 날짜로부터 더할 시간 간격 값(interval value)을 의미하며, INTERVAL 키워드 뒤에 음수가 명시되면 시작 날짜로부터 시간 간격 값을 뺀다.

  • unitexpr 수식에 명시된 시간 간격 값의 단위를 의미하며, 아래의 테이블을 참고하여 시간 간격 값 해석을 위한 형식을 지정할 수 있다. expr 의 단위 값이 unit 에서 요구하는 단위 값의 개수보다 적을 경우 가장 작은 단위부터 채운다. 예를 들어, HOUR_SECOND 의 경우 ‘HOURS:MINUTES:SECONDS’와 같이 3개의 값이 요구되는데, “1:1” 처럼 2개의 값만 주어지면 ‘MINUTES:SECONDS’로 간주한다.

Return type:

DATE 또는 DATETIME

unit에 대한 expr 형식

unit 값

expr 형식

MILLISECOND

MILLISECONDS

ADDDATE(SYSDATE, INTERVAL 123 MILLISECOND)

SECOND

SECONDS

ADDDATE(SYSDATE, INTERVAL 123 SECOND)

MINUTE

MINUTES

ADDDATE(SYSDATE, INTERVAL 123 MINUTE)

HOUR

HOURS

ADDDATE(SYSDATE, INTERVAL 123 HOUR)

DAY

DAYS

ADDDATE(SYSDATE, INTERVAL 123 DAY)

WEEK

WEEKS

ADDDATE(SYSDATE, INTERVAL 123 WEEK)

MONTH

MONTHS

ADDDATE(SYSDATE, INTERVAL 12 MONTH)

QUARTER

QUARTERS

ADDDATE(SYSDATE, INTERVAL 12 QUARTER)

YEAR

YEARS

ADDDATE(SYSDATE, INTERVAL 12 YEAR)

SECOND_MILLISECOND

‘SECONDS.MILLISECONDS’

ADDDATE(SYSDATE, INTERVAL ‘12.123’ SECOND_MILLISECOND)

MINUTE_MILLISECOND

‘MINUTES:SECONDS.MILLISECONDS’

ADDDATE(SYSDATE, INTERVAL ‘12:12.123’ MINUTE_MILLISECOND)

MINUTE_SECOND

‘MINUTES:SECONDS’

ADDDATE(SYSDATE, INTERVAL ‘12:12’ MINUTE_SECOND)

HOUR_MILLISECOND

‘HOURS:MINUTES:SECONDS.MILLISECONDS’

ADDDATE(SYSDATE, INTERVAL ‘12:12:12.123’ HOUR_MILLISECOND)

HOUR_SECOND

‘HOURS:MINUTES:SECONDS’

ADDDATE(SYSDATE, INTERVAL ‘12:12:12’ HOUR_SECOND)

HOUR_MINUTE

‘HOURS:MINUTES’

ADDDATE(SYSDATE, INTERVAL ‘12:12’ HOUR_MINUTE)

DAY_MILLISECOND

‘DAYS HOURS:MINUTES:SECONDS.MILLISECONDS’

ADDDATE(SYSDATE, INTERVAL ‘12 12:12:12.123’ DAY_MILLISECOND)

DAY_SECOND

‘DAYS HOURS:MINUTES:SECONDS’

ADDDATE(SYSDATE, INTERVAL ‘12 12:12:12’ DAY_SECOND)

DAY_MINUTE

‘DAYS HOURS:MINUTES’

ADDDATE(SYSDATE, INTERVAL ‘12 12:12’ DAY_MINUTE)

DAY_HOUR

‘DAYS HOURS’

ADDDATE(SYSDATE, INTERVAL ‘12 12’ DAY_HOUR)

YEAR_MONTH

‘YEARS-MONTHS’

ADDDATE(SYSDATE, INTERVAL ‘12-13’ YEAR_MONTH)

SELECT SYSDATE, ADDDATE(SYSDATE,INTERVAL 24 HOUR), ADDDATE(SYSDATE, 1);
03/30/2010  12:00:00.000 AM 03/31/2010               03/31/2010
--it subtracts days when argument < 0
SELECT SYSDATE, ADDDATE(SYSDATE,INTERVAL -24 HOUR), ADDDATE(SYSDATE, -1);
03/30/2010  12:00:00.000 AM 03/29/2010               03/29/2010
--when expr is not fully specified for unit
SELECT SYS_DATETIME, ADDDATE(SYS_DATETIME, INTERVAL '1:20' HOUR_SECOND);
06:18:24.149 PM 06/28/2010     06:19:44.149 PM 06/28/2010
SELECT ADDDATE('0000-00-00', 1 );
ERROR: Conversion error in date format.
SELECT ADDDATE('0001-01-01 00:00:00', -1);
'12:00:00.000 AM 00/00/0000'

ADDTIME

ADDTIME(expr1, expr2)

ADDTIME 함수는 특정 시간 값에 대해 덧셈 또는 뺄셈을 실행한다. 첫 번째 인자는 DATE, DATETIME, TIMESTAMP 또는 TIME 타입이며, 두 번째 인자는 TIME, DATETIME 또는 TIMESTAMP 타입이다. 두 번째 인자는 반드시 시간을 포함해야 하며, 두 번째 인자의 날짜는 무시된다. 각 인자의 타입에 따른 반환 타입은 다음과 같다.

첫 번째 인자 타입

두 번째 인자 타입

반환 타입

참고

TIME

TIME, DATETIME, TIMESTAMP

TIME

결과 값은 24시를 넘어서는 안 된다.

DATE

TIME, DATETIME, TIMESTAMP

DATETIME

DATETIME

TIME, DATETIME, TIMESTAMP

DATETIME

날짜/시간 문자열

TIME, DATETIME, TIMESTAMP 또는 시간 문자열

VARCHAR

결과 문자열은 시간을 포함한 문자열이다.

Parameters:
  • expr1DATE, DATETIME, TIMESTAMP, TIME 타입 또는 날짜/시간 문자열

  • expr2DATETIME, TIMESTAMP, TIME 타입 또는 시간 문자열

SELECT ADDTIME(datetime'2007-12-31 23:59:59', time'1:1:2');
01:01:01.000 AM 01/01/2008
SELECT ADDTIME(time'01:00:00', time'02:00:01');
03:00:01 AM

ADD_MONTHS

ADD_MONTHS(date_argument, month)

ADD_MONTHS 함수는 DATE 타입의 date_argument 표현식에 month 값을 더하고 DATE 타입 값을 반환한다. 인자로 지정된 값의 일(dd)이 연산 결과 값의 월에 존재하면 해당 일(dd)을 반환한다. 존재하지 않으면 해당 월의 마지막 날(dd)을 반환한다. 연산 결과 값이 DATE 타입의 표현식 범위를 초과하는 경우 오류를 반환한다.

Parameters:
  • date_argumentDATE 타입의 표현식을 지정한다. TIMESTAMP 또는 DATETIME 값을 지정하려면 DATE 타입으로 명시적 변환을 해야 한다. 값이 NULL 이면 NULL 을 반환한다.

  • monthdate_argument 에 더할 개월 수를 지정한다. 양수와 음수 모두 지정할 수 있다. 지정한 값이 정수 타입이 아닐 경우 자동으로 정수 타입으로 변환(소수점 아래 첫째 자리를 반올림 처리)된다. 값이 NULL 이면 NULL 을 반환한다.

--it returns DATE type value by adding month to the first argument
SELECT ADD_MONTHS(DATE '2008-12-25', 5), ADD_MONTHS(DATE '2008-12-25', -5);
05/25/2009                         07/25/2008
SELECT ADD_MONTHS(DATE '2008-12-31', 5.5), ADD_MONTHS(DATE '2008-12-31', -5.5);
06/30/2009                           06/30/2008
SELECT ADD_MONTHS(CAST (SYS_DATETIME AS DATE), 5), ADD_MONTHS(CAST (SYS_TIMESTAMP AS DATE), 5);
07/03/2010                                     07/03/2010

다음은 타임존 타입 값 사용 예이다. 타임존 관련 설명은 타임존이 있는 날짜/시간 데이터 타입 을 참고한다.

SELECT ADD_MONTHS (datetimeltz'2001-10-11 10:11:12', 1);
11/11/2001
SELECT ADD_MONTHS (datetimetz'2001-10-11 10:11:12 Europe/Paris', 1);
11/11/2001
SELECT ADD_MONTHS (timestampltz'2001-10-11 10:11:12', 1);
11/11/2001
SELECT ADD_MONTHS (timestamptz'2001-10-11 10:11:12 Europe/Paris', 1);
11/11/2001

CURDATE, CURRENT_DATE

CURDATE()
CURRENT_DATE()
CURRENT_DATE

CURDATE (), CURRENT_DATECURRENT_DATE () 는 서로 바꿔 사용할 수 있으며 세션의 현재 날짜를 DATE 타입(MM/DD/YYYY 또는 YYYY-MM-DD)으로 반환한다. 산술 연산의 단위는 일이다. 현재 세션의 타임존이 서버의 타임존과 동일하면 함수는 SYS_DATE, SYSDATE 와 동일하다. 차이점은 SYS_DATE, SYSDATE 및 다음 예를 참고하고, 함수에 대한 자세한 내용은 DBTIMEZONE(), SESSIONTIMEZONE() 을 참고한다.

입력 인자의 연, 월, 일이 모두 0이면 반환되는 값은 return_null_on_function_errors 시스템 변수에 의해서 결정된다. 그 변수가 yes로 설정되었으면 NULL 이 반환된다. 그 변수가 no로 설정되었으면 오류가 반환된다. 기본값은 no 이다.

Return type:

DATE

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'Asia/Seoul'

-- it returns the current date in DATE type

SELECT CURDATE(), CURRENT_DATE(), CURRENT_DATE, SYS_DATE, SYSDATE;

   CURRENT_DATE    CURRENT_DATE    CURRENT_DATE    SYS_DATE    SYS_DATE
========================================================================
  02/05/2016      02/05/2016      02/05/2016      02/05/2016  02/05/2016
-- it returns the date 60 days added to the current date

SELECT CURDATE()+60;

   CURRENT_DATE +60
 ===================
   04/05/2016
-- change session time from 'Asia/Seoul' to 'America/Los_Angeles'

SET TIME ZONE 'America/Los_Angeles';

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'America/Los_Angeles'

-- Note that CURDATE() and SYS_DATE returns different results

SELECT CURDATE(), CURRENT_DATE(), CURRENT_DATE, SYS_DATE, SYSDATE;

   CURRENT_DATE    CURRENT_DATE    CURRENT_DATE    SYS_DATE    SYS_DATE
========================================================================
  02/04/2016      02/04/2016      02/04/2016      02/05/2016  02/05/2016

Warning

10.0 이후로 CURDATE (), CURRENT_DATE, CURRENT_DATE ()가 SYS_DATESYSDATE 와 다르다. 9.x 및 그 이전 버전에서는 동일하다.

CURRENT_DATETIME, NOW

CURRENT_DATETIME()
CURRENT_DATETIME
NOW()

CURRENT_DATETIME, CURRENT_DATETIME () 및 NOW ()는 서로 바꿔 사용할 수 있으며 세션의 현재 날짜와 시간을 DATETIME 타입으로 반환한다. 산술 연산의 단위는 밀리초(msec)이다. 현재 세션의 타임존이 서버의 타임존과 동일하면 함수는 SYS_DATETIME, SYSDATETIME 과 동일하다. 차이점은 SYS_DATETIME, SYSDATETIME 을 참고하고, 함수에 대한 자세한 내용은 DBTIMEZONE(), SESSIONTIMEZONE() 을 참고한다.

Return type:

DATETIME

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'Asia/Seoul'

-- it returns the current date and time in DATETIME type

SELECT NOW(), SYS_DATETIME;

   CURRENT_DATETIME               SYS_DATETIME
==============================================================
  04:05:09.292 PM 02/05/2016     04:05:09.292 PM 02/05/2016
-- it returns the timestamp value 1 hour added to the current sys_datetime value

SELECT TO_CHAR(SYSDATETIME+3600*1000, 'YYYY-MM-DD HH24:MI');

   to_char( SYS_DATETIME +3600*1000, 'YYYY-MM-DD HH24:MI')
======================
  '2016-02-05 17:05'
-- change session time from 'Asia/Seoul' to 'America/Los_Angeles'

set time zone 'America/Los_Angeles';

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'America/Los_Angeles'

-- NOW()와 SYS_DATETIME은 서로 다른 결과를 반환하므로 주의한다.

SELECT NOW(), SYS_DATETIME;

   CURRENT_DATETIME               SYS_DATETIME
==============================================================
  11:08:57.041 PM 02/04/2016     04:08:57.041 PM 02/05/2016

Warning

10.0 이후로 CURRENT_DATETIME (), NOW ()가 SYS_DATEIME, SYSDATETIME 과 다르다. 9.x 및 그 이전 버전에서는 동일하다.

CURTIME, CURRENT_TIME

CURTIME()
CURRENT_TIME
CURRENT_TIME()

CURTIME (), CURRENT_TIMECURRENT_TIME ()은 서로 바꿔 사용할 수 있으며 세션의 현재 시간을 TIME 타입(HH:MI:SS)으로 반환한다. 산술 연산의 단위는 초(sec)이다. 현재 세션의 타임존이 서버의 타임존과 동일하면 함수는 SYS_TIME, SYSTIME 과 동일하다. 차이점은 SYS_TIME, SYSTIME 을 참고하고, 함수에 대한 자세한 내용은 DBTIMEZONE(), SESSIONTIMEZONE() 을 참고한다.

Return type:

TIME

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'Asia/Seoul'

-- it returns the current time in TIME type

SELECT CURTIME(), CURRENT_TIME(), CURRENT_TIME, SYS_TIME, SYSTIME;

   CURRENT_TIME    CURRENT_TIME    CURRENT_TIME    SYS_TIME     SYS_TIME
==========================================================================
  04:22:54 PM     04:22:54 PM     04:22:54 PM     04:22:54 PM  04:22:54 PM
-- change session time from 'Asia/Seoul' to 'America/Los_Angeles'

SET TIME ZONE 'AMERICA/LOS_ANGELES';

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'America/Los_Angeles'

-- Note that CURTIME() and SYS_TIME return different results

SELECT CURTIME(), CURRENT_TIME(), CURRENT_TIME, SYS_TIME, SYSTIME;

   CURRENT_TIME    CURRENT_TIME    CURRENT_TIME    SYS_TIME     SYS_TIME
==========================================================================
  11:23:16 PM     11:23:16 PM     11:23:16 PM     04:23:16 PM  04:23:16 PM

Warning

10.0 이후로 CURTIME (), CURRENT_TIME ()이 SYS_TIME, SYSTIME 과 다르다. 9.x 및 그 이전 버전에서는 동일하다.

CURRENT_TIMESTAMP, LOCALTIME, LOCALTIMESTAMP

CURRENT_TIMESTAMP
CURRENT_TIMESTAMP()
LOCALTIME
LOCALTIME()
LOCALTIMESTAMP
LOCALTIMESTAMP()

CURRENT_TIMESTAMP, CURRENT_TIMESTAMP (), LOCALTIME, LOCALTIME (), LOCALTIMESTAMP, LOCALTIMESTAMP ()는 동일하며, 현재 날짜와 시간을 TIMESTAMP 타입으로 반환한다. 산술 연산의 단위는 초(sec)다. 현재 세션의 타임존이 서버의 타임존과 동일하면 함수는 SYS_TIMESTAMP, SYSTIMESTAMP 와 동일하다. 차이점은 SYS_TIMESTAMP, SYSTIMESTAMP 를 참고하고, 함수에 대한 자세한 내용은 DBTIMEZONE(), SESSIONTIMEZONE() 을 참고한다.

Return type:

TIMESTAMP

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'Asia/Seoul'

-- it returns the current date and time in TIMESTAMP type of session and server timezones.

SELECT LOCALTIME, SYS_TIMESTAMP;

   CURRENT_TIMESTAMP          SYS_TIMESTAMP
======================================================
  04:34:16 PM 02/05/2016     04:34:16 PM 02/05/2016
-- change session time from 'Asia/Seoul' to 'America/Los_Angeles'

SET TIME ZONE 'America/Los_Angeles';

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'America/Los_Angeles'

-- Note that LOCALTIME() and SYS_TIMESTAMP return different results

SELECT LOCALTIME, SYS_TIMESTAMP;

   CURRENT_TIMESTAMP          SYS_TIMESTAMP
======================================================
  11:34:37 PM 02/04/2016     04:34:37 PM 02/05/2016

Warning

10.0 이후로 CURRENT_TIMESTAMP, CURRENT_TIMESTAMP (), LOCALTIME, LOCALTIME (), LOCALTIMESTAMPLOCALTIMESTAMP ()가 SYS_TIMESTAMP (), SYSTIMESTAMP 와 다르다. 9.x 및 그 이전 버전에서는 동일하다.

DATE

DATE(date)

DATE 함수는 지정된 인자로부터 날짜 부분을 추출하여 ‘MM/DD/YYYY’ 형식 문자열로 반환한다. 지정 가능한 인자는 DATE, TIMESTAMP, DATETIME 타입이며, 리턴 값은 VARCHAR 타입이다

인자의 연, 월, 일에는 0을 입력할 수 없으나, 예외적으로 날짜와 시간이 모두 0인 값을 입력한 경우에는 연, 월, 일 값이 모두 0인 문자열을 반환한다.

Parameters:

dateDATE, TIMESTAMP, DATETIME 타입이 지정될 수 있다.

Return type:

STRING

SELECT DATE('2010-02-27 15:10:23');
'02/27/2010'
SELECT DATE(NOW());
'04/01/2010'
SELECT DATE('0000-00-00 00:00:00');
'00/00/0000'

DATEDIFF

DATEDIFF(date1, date2)

DATEDIFF 함수는 주어진 두 개의 인자로부터 날짜 부분을 추출하여 두 값의 차이를 일 단위 정수로 반환한다. 지정 가능한 인자는 DATE, TIMESTAMP, DATETIME 타입이며, 리턴 값의 타입은 INTEGER 이다.

입력 인자의 날짜와 시간 값이 모두 0이면 시스템 파라미터 return_null_on_function_errors 의 값에 따라 다른 값을 반환한다. return_null_on_function_errors 가 yes이면 NULL 을 반환하고 no이면 에러를 반환하며, 기본값은 no 이다.

Parameters:

date1,date2 – 날짜를 포함하는 타입(DATE, TIMESTAMP, DATETIME) 또는 해당 타입의 값을 나타내는 문자열이 지정될 수 있다. 유효하지 않은 문자열이 지정되면 에러를 반환한다.

Return type:

INT

SELECT DATEDIFF('2010-2-28 23:59:59','2010-03-02');
-2
SELECT DATEDIFF('0000-00-00 00:00:00', '2010-2-28 23:59:59');
ERROR: Conversion error in date format.

다음은 타임존 타입의 값을 사용하는 예이다. 타임존과 관련된 설명은 타임존이 있는 날짜/시간 데이터 타입을 참고한다.

SELECT IF(DATEDIFF('2002-03-03 12:00:00 AM','1990-01-01 11:59:59 PM') = DATEDIFF(timestampltz'2002-03-03 12:00:00 AM',timestampltz'1990-01-01 11:59:59 PM'),'ok','nok');
'ok'

DATE_SUB, SUBDATE

DATE_SUB(date, INTERVAL expr unit)
SUBDATE(date, INTERVAL expr unit)
SUBDATE(date, days)

DATE_SUB ()와 SUBDATE ()는 동일하며, 특정 DATE 값에 대해 뺄셈 또는 덧셈을 실행한다. 리턴 값은 DATE 타입 또는 DATETIME 타입이다. 연산 결과의 날짜가 해당 월의 마지막 날짜를 초과하면, 해당 월의 말일을 적용하여 유효한 DATE 값을 반환한다.

입력 인자의 날짜와 시간 값이 모두 0이면 시스템 파라미터 return_null_on_function_errors 의 값에 따라 다른 값을 반환한다. return_null_on_function_errors 가 yes이면 NULL 을 반환하고 no이면 에러를 반환하며, 기본값은 no 이다.

계산 결과가 ‘0000-00-00 00:00:00’과 ‘0001-01-01 00:00:00’ 사이이면, 날짜와 시간 값이 모두 0인 DATE 또는 DATETIME 타입의 값을 반환한다. 그러나 JDBC 프로그램에서는 연결 URL 속성인 zeroDateTimeBehavior의 설정에 따라 동작이 달라진다(“API 레퍼런스 > JDBC API > JDBC 프로그래밍 > 연결 설정” 참고).

param date:

DATE, DATETIME 또는 TIMESTAMP 타입의 연산식이며, 시작 날짜를 의미한다. 만약, ‘2006-07-00’와 같이 유효하지 않은 DATE 값이 지정되면, 에러를 반환한다.

param expr:

시작 날짜로부터 뺄 시간 간격 값(interval value)을 의미하며, INTERVAL 키워드 뒤에 음수가 명시되면 시작 날짜로부터 시간 간격 값을 더한다.

param unit:

expr 수식에 명시된 시간 간격 값의 단위를 의미하며, unit 값에 대한 expr 인자의 값은 ADDDATE() 의 표를 참고한다.

rtype:

DATE or DATETIME

SELECT SYSDATE, SUBDATE(SYSDATE,INTERVAL 24 HOUR), SUBDATE(SYSDATE, 1);
03/30/2010  12:00:00.000 AM 03/29/2010               03/29/2010
-- 인수 < 0 일때, 날짜를 더한다
SELECT SYSDATE, SUBDATE(SYSDATE,INTERVAL -24 HOUR), SUBDATE(SYSDATE, -1);
03/30/2010  12:00:00.000 AM 03/31/2010               03/31/2010
SELECT SUBDATE('0000-00-00 00:00:00', -50);
ERROR: Conversion error in date format.
SELECT SUBDATE('0001-01-01 00:00:00', 10);
'12:00:00.000 AM 00/00/0000'

DAY, DAYOFMONTH

DAY(date)
DAYOFMONTH(date)

DAY 함수와 DAYOFMONTH 함수는 동일하며, 지정된 인자로부터 1~31 범위의 일(day)을 반환한다. 인자로 DATE, TIMESTAMP, DATETIME 타입의 값을 지정할 수 있으며, INTEGER 타입의 값을 반환한다.

인자의 연, 월, 일에는 0을 입력할 수 없으나, 예외적으로 연, 월, 일이 모두 0인 값을 입력한 경우에는 0을 반환한다.

Parameters:

date – 날짜

Return type:

INT

SELECT DAYOFMONTH('2010-09-09');
9
SELECT DAY('2010-09-09 19:49:29');
9
SELECT DAYOFMONTH('0000-00-00 00:00:00');
0

DAYOFWEEK

DAYOFWEEK(date)

DAYOFWEEK 함수는 지정된 인자로부터 1~7 범위의 요일(1: 일요일, 2: 월요일, …, 7: 토요일)을 반환한다. 요일 인덱스는 ODBC 표준과 같다. 인자로 DATE, TIMESTAMP, DATETIME 타입의 값을 지정할 수 있으며, INTEGER 타입의 값을 반환한다.

입력 인자의 연, 월, 일이 모두 0이면 시스템 파라미터 return_null_on_function_errors 의 값에 따라 다른 값을 반환한다. return_null_on_function_errors 가 yes이면 NULL 을 반환하고 no이면 에러를 반환하며, 기본값은 no 이다.

Parameters:

date – 날짜

Return type:

INT

SELECT DAYOFWEEK('2010-09-09');
5
SELECT DAYOFWEEK('2010-09-09 19:49:29');
5
SELECT DAYOFWEEK('0000-00-00');
ERROR: Conversion error in date format.

DAYOFYEAR

DAYOFYEAR(date)

DAYOFYEAR 함수는 지정된 인자로부터 1~366 범위의 일(day of year)을 반환한다. 인자로 DATE, TIMESTAMP, DATETIME 타입의 값을 지정할 수 있으며, INTEGER 타입의 값을 반환한다.

입력 인자의 날짜 값이 모두 0이면 시스템 파라미터 return_null_on_function_errors 의 값에 따라 다른 값을 반환한다. return_null_on_function_errors 가 yes이면 NULL 을 반환하고 no이면 에러를 반환하며, 기본값은 no 이다.

Parameters:

date – 날짜

Return type:

INT

SELECT DAYOFYEAR('2010-09-09');
252
SELECT DAYOFYEAR('2010-09-09 19:49:29');
252
SELECT DAYOFYEAR('0000-00-00');
ERROR: Conversion error in date format.

EXTRACT

EXTRACT(field FROM date-time_argument)

EXTRACT 연산자는 날짜/시간 값을 반환하는 연산식 date-time_argument 중 일부분을 추출하여 INTEGER 타입으로 반환한다.

입력 인자의 연, 월, 일에는 0을 입력할 수 없으나, 예외적으로 날짜와 시간이 모두 0인 값을 입력한 경우에는 0을 반환한다.

Parameters:
  • field – 날짜/시간 수식에서 추출할 값을 지정한다. (YEAR, MONTH, DAY, HOUR, MINUTE, SECOND, MILLISECOND)

  • date-time_argument – 날짜/시간 값을 반환하는 연산식이다. 이 연산식의 값은 TIME, DATE, TIMESTAMP, DATETIME 타입 중 하나여야 하며, NULL 이 지정된 경우에는 NULL 값이 반환된다.

Return type:

INT

SELECT EXTRACT(MONTH FROM DATETIME '2008-12-25 10:30:20.123' );
12
SELECT EXTRACT(HOUR FROM DATETIME '2008-12-25 10:30:20.123' );
10
SELECT EXTRACT(MILLISECOND FROM DATETIME '2008-12-25 10:30:20.123' );
123
SELECT EXTRACT(MONTH FROM '0000-00-00 00:00:00');
0

다음은 타임존 타입의 값을 사용하는 예이다. 타임존과 관련된 설명은 타임존이 있는 날짜/시간 데이터 타입을 참고한다.

SELECT EXTRACT (MONTH FROM datetimetz'10/15/1986 5:45:15.135 am Europe/Bucharest');
10
SELECT EXTRACT (MONTH FROM datetimeltz'10/15/1986 5:45:15.135 am Europe/Bucharest');
10
SELECT EXTRACT (MONTH FROM timestampltz'10/15/1986 5:45:15 am Europe/Bucharest');
10
SELECT EXTRACT (MONTH FROM timestamptz'10/15/1986 5:45:15 am Europe/Bucharest');
10

FROM_DAYS

FROM_DAYS(N)

FROM_DAYS 함수는 INTEGER 타입을 인자로 입력하면 DATE 타입의 날짜를 반환한다.

FROM_DAYS 함수는 그레고리력(Gregorian Calendar) 출현(1582년) 이전은 고려하지 않았으므로 1582년 앞의 날짜에 대해서는 사용하지 않는 것을 권장한다.

인자로 0~3,652,424 범위의 정수를 입력할 수 있다. 0~365 범위의 값을 인자로 입력하면 0을 반환한다. 최대값인 3,652,424는 9999년의 마지막 날을 의미한다.

Parameters:

N – 0~3,652,424 범위의 정수

Return type:

DATE

SELECT FROM_DAYS(719528);
01/01/1970
SELECT FROM_DAYS('366');
01/03/0001
SELECT FROM_DAYS(3652424);
12/31/9999
SELECT FROM_DAYS(0);
00/00/0000

FROM_TZ

FROM_TZ(datetime, timezone_string)

DATETIME 타입 값에 타임존을 더하여 타임존이 없는 날짜/시간 타입을 타임존이 있는 날짜/시간 타입으로 변환한다. 입력 값 타입은 DATETIME이고 결과 값 타입은 DATETIMETZ이다.

Parameters:
  • datetime – DATETIME

  • timezone_string – 타임존명(‘Asia/Seoul’) 또는 오프셋(‘+05:00’)을 나타내는 문자열

Return type:

DATETIMETZ

SELECT FROM_TZ(datetime '10/10/2014 00:00:00 AM', 'Europe/Vienna');
12:00:00.000 AM 10/10/2014 Europe/Vienna CEST
SELECT FROM_TZ(datetime '10/10/2014 23:59:59 PM', '+03:25:25');
11:59:59.000 PM 10/10/2014 +03:25:25

타임존과 관련된 설명은 타임존이 있는 날짜/시간 데이터 타입을 참고한다.

FROM_UNIXTIME

FROM_UNIXTIME(unix_timestamp[, format])

FROM_UNIXTIME 함수는 format 인자가 명시된 경우 VARCHAR 타입으로 해당 형식의 문자열을 반환하며, format 인자가 생략될 경우 TIMESTASMP 타입의 값을 반환한다. unix_timestamp 인자로 UNIX의 타임스탬프에 해당하는 INTEGER 타입을 입력한다. 리턴 값은 현재의 타임 존으로 표현된다.

format에 입력하는 시간 형식은 DATE_FORMAT() 의 날짜/시간 형식 2를 따른다.

TIMESTAMP와 UNIX 타임스탬프는 일대일 대응 관계가 아니기 때문에 변환할 때 UNIX_TIMESTAMP() 함수나 FROM_UNIXTIME 함수를 사용하면 값의 일부가 유실될 수 있다. 자세한 설명은 UNIX_TIMESTAMP() 를 참고한다.

인자의 연, 월, 일에는 0을 입력할 수 없으나, 예외적으로 날짜와 시간이 모두 0인 값을 입력한 경우에는 날짜와 시간 값이 모두 0인 문자열을 반환한다. 그러나 JDBC 프로그램에서는 연결 URL 속성인 zeroDateTimeBehavior의 설정에 따라 동작이 달라진다(“API 레퍼런스 > JDBC API > JDBC 프로그래밍 > 연결 설정” 참고).

Parameters:
  • unix_timestamp – 양의 정수

  • format – 시간 형식. DATE_FORMAT() 의 날짜/시간 형식 2를 따른다.

Return type:

STRING, INT

SELECT FROM_UNIXTIME(1234567890);
01:31:30 AM 02/14/2009
SELECT FROM_UNIXTIME('1000000000');
04:46:40 AM 09/09/2001
SELECT FROM_UNIXTIME(1234567890,'%M %Y %W');
'February 2009 Saturday'
SELECT FROM_UNIXTIME('1234567890','%M %Y %W');
'February 2009 Saturday'
SELECT FROM_UNIXTIME(0);
12:00:00 AM 00/00/0000

HOUR

HOUR(time)

HOUR 함수는 지정된 인자로부터 시(hour) 부분을 추출한 정수를 반환한다. 인자로 TIME, TIMESTAMP, DATETIME 타입의 값을 지정할 수 있으며, INTEGER 타입의 값을 반환한다.

Parameters:

time – 시간

Return type:

INT

SELECT HOUR('12:34:56');
12
SELECT HOUR('2010-01-01 12:34:56');
12
SELECT HOUR(datetime'2010-01-01 12:34:56');
12

LAST_DAY

LAST_DAY(date_argument)

LAST_DAY 함수는 인자로 지정된 DATE 값에서 해당 월의 마지막 날짜 값을 DATE 타입으로 반환한다.

입력 인자의 연, 월, 일이 모두 0이면 시스템 파라미터 return_null_on_function_errors 의 값에 따라 다른 값을 반환한다. return_null_on_function_errors 가 yes이면 NULL 을 반환하고 no이면 에러를 반환하며, 기본값은 no 이다.

Parameters:

date_argumentDATE 타입의 연산식을 지정한다. TIMESTAMPDATETIME 값을 지정하려면 DATE 타입으로 명시적 변환을 해야 한다. 값이 NULL 이면 NULL 을 반환한다.

Return type:

DATE

--it returns last day of the month in DATE type
SELECT LAST_DAY(DATE '1980-02-01'), LAST_DAY(DATE '2010-02-01');
02/28/1980                    02/28/2010
--it returns last day of the month when explicitly casted to DATE type
SELECT LAST_DAY(CAST (SYS_TIMESTAMP AS DATE)), LAST_DAY(CAST (SYS_DATETIME AS DATE));
02/28/2010                                 02/28/2010
SELECT LAST_DAY('0000-00-00');
ERROR: Conversion error in date format.

MAKEDATE

MAKEDATE(year, dayofyear)

MAKEDATE 함수는 지정된 인자로부터 날짜를 반환한다. 인자로 1~9999 범위의 연도와 일(day of year)에 해당하는 INTEGER 타입의 값을 지정할 수 있으며, 1/1/1~12/31/9999 범위의 DATE 타입의 값을 반환한다. 일(day of year)이 해당 연도를 넘어가면 다음 연도가 된다. 예를 들어, MAKEDATE(1999, 366)은 2000-01-01을 반환한다. 단, 연도에 0~69 범위의 값을 입력하면 2000년~2069년으로 처리하고, 70~99 범위의 값을 입력하면 1970년~1999년으로 처리한다.

yeardayofyear 가 모두 0이면 시스템 파라미터 return_null_on_function_errors 의 값에 따라 다른 값을 반환한다. return_null_on_function_errors 가 yes이면 NULL 을 반환하고 no이면 에러를 반환하며, 기본값은 no 이다.

Parameters:
  • year – 1~9999 범위의 연도

  • dayofyear – 연도에 0~99의 값을 입력하면 예외적으로 처리하므로, 실제로는 100년 이후의 연도만 사용된다. 따라서 dayofyear 의 최대값은 3,615,902이며, MAKEDATE(100, 3615902)는 9999/12/31을 반환한다.

Return type:

DATE

SELECT MAKEDATE(2010,277);
10/04/2010
SELECT MAKEDATE(10,277);
10/04/2010
SELECT MAKEDATE(70,277);
10/04/1970
SELECT MAKEDATE(100,3615902);
12/31/9999
SELECT MAKEDATE(9999,365);
12/31/9999
SELECT MAKEDATE(0,0);
ERROR: Conversion error in date format.

MAKETIME

MAKETIME(hour, min, sec)

MAKETIME 함수는 지정된 인자로부터 시간을 AM/PM 형태로 반환한다. 인자로 시각, 분, 초에 해당하는 INTEGER 타입의 값을 지정할 수 있으며, DATETIME 타입의 값을 반환한다.

Parameters:
  • hour – 시를 나타내는 0~23 범위의 정수

  • min – 분을 나타내는 0~59 범위의 정수

  • sec – 초를 나타내는 0~59 범위의 정수

Return type:

DATETIME

SELECT MAKETIME(13,34,4);
01:34:04 PM
SELECT MAKETIME('1','34','4');
01:34:04 AM
SELECT MAKETIME(24,0,0);
ERROR: Conversion error in time format.

MINUTE

MINUTE(time)

MINUTE 함수는 지정된 인자로부터 0~59 범위의 분(minute)을 반환한다. 인자로 TIME, TIMESTAMP, DATETIME 타입의 값을 지정할 수 있으며, INTEGER 타입의 값을 반환한다.

Parameters:

time – 시간

Return type:

INT

SELECT MINUTE('12:34:56');
34
SELECT MINUTE('2010-01-01 12:34:56');
34
SELECT MINUTE('2010-01-01 12:34:56.7890');
34

MONTH

MONTH(date)

MONTH 함수는 지정된 인자로부터 1~12 범위의 월(month)을 반환한다. 인자로 DATE, TIMESTAMP, DATETIME 타입의 값을 지정할 수 있으며, INTEGER 타입의 값을 반환한다.

인자의 연, 월, 일에는 0을 입력할 수 없으나, 예외적으로 날짜가 모두 0인 값을 입력한 경우에는 0을 반환한다.

Parameters:

date – 날짜

Return type:

INT

SELECT MONTH('2010-01-02');
1
SELECT MONTH('2010-01-02 12:34:56');
1
SELECT MONTH('2010-01-02 12:34:56.7890');
1
SELECT MONTH('0000-00-00');
0

MONTHS_BETWEEN

MONTHS_BETWEEN (date_argument, date_argument)

MONTHS_BETWEEN 함수는 주어진 두 개의 DATE 값 간의 차이를 월 단위로 반환하며, 리턴 값은 DOUBLE 타입이다. 인자로 지정된 두 날짜가 동일하거나, 해당 월의 말일인 경우에는 정수 값을 반환하지만, 그 외의 경우에는 날짜 차이를 31로 나눈 값을 반환한다.

Parameters:

date_argumentDATE 타입의 값을 가지는 연산식을 지정한다. TIMESTAMPDATETIME 값도 지정할 수 있다. 값이 NULL 이면 NULL 을 반환한다.

Return type:

DOUBLE

--첫번째 인수가 이전 날짜일 때 음수의 달수를 반환한다
SELECT MONTHS_BETWEEN(DATE '2008-12-31', DATE '2010-6-30');
-1.800000000000000e+001
--각각의 날짜가 그 달의 마지막 날일 때 정수를 반환한다
SELECT MONTHS_BETWEEN(DATE '2010-6-30', DATE '2008-12-31');
1.800000000000000e+001
--두 개의 인수가 명시적으로 DATE 타입으로 형 변환된 경우는 달 수를 반환한다
SELECT MONTHS_BETWEEN(CAST (SYS_TIMESTAMP AS DATE), DATE '2008-12-25');
1.332258064516129e+001
--두 개의 인수가 명시적으로 DATE 타입으로 형 변환된 경우는 달 수를 반환한다
SELECT MONTHS_BETWEEN(CAST (SYS_DATETIME AS DATE), DATE '2008-12-25');
1.332258064516129e+001

다음은 타임존 타입의 값을 이용하는 예제이다. 타임존 관련된 기술에 대헤서는 다음을 참조하라, 타임존이 있는 날짜/시간 데이터 타입.

SELECT MONTHS_BETWEEN(datetimetz'2001-10-11 10:11:12 +02:00', datetimetz'2001-05-11 10:11:12 +03:00');
5.000000000000000e+00

NEW_TIME

NEW_TIME(src_datetime, src_timezone, dst_timezone)

어떤 타임존에서 다른 타임존으로 날짜 값을 이동한다. src_datetime에는 DATETIME 또는 TIME 타입의 값을 입력하며, 반환 값의 타입은 src_datetime과 동일하다.

Parameters:
  • src_datetime – DATETIME 또는 TIME 타입의 입력 값

  • src_timezone – 원본 타임존의 지역 이름

  • dst_timezion – 대상 타임존의 지역 이름

Return type:

src_datetime의 타입과 동일한 타입

SELECT NEW_TIME(datetime '10/10/2014 10:10:10 AM', 'Europe/Vienna', 'Europe/Bucharest');
11:10:10.000 AM 10/10/2014

TIME 타입의 경우 타임존 인자로 오프셋만 허용하며, 지역 이름은 허용하지 않는다.

SELECT NEW_TIME(time '10:10:10 PM', '+03:00', '+10:00');
05:10:10 AM

타임존과 관련된 설명은 타임존이 있는 날짜/시간 데이터 타입을 참고한다.

QUARTER

QUARTER(date)

QUARTER 함수는 지정된 인자로부터 1~4 범위의 분기(quarter)를 반환한다. 인자로 DATE, TIMESTAMP, DATETIME 타입의 값을 지정할 수 있으며, INTEGER 타입의 값을 반환한다.

Parameters:

date – 날짜

Return type:

INT

SELECT QUARTER('2010-05-05');
2
SELECT QUARTER('2010-05-05 12:34:56');
2
SELECT QUARTER('2010-05-05 12:34:56.7890');
2

다음은 타임존 타입의 값을 사용하는 예이다. 타임존과 관련된 설명은 타임존이 있는 날짜/시간 데이터 타입을 참고한다.

SELECT QUARTER('2008-04-01 01:02:03 Asia/Seoul');
2
SELECT QUARTER(datetimetz'2003-12-31 01:02:03.1234 Europe/Paris');
4

ROUND

ROUND(date, fmt)

fmt 에서 지정한 단위의 값으로 반올림한다. DATE 타입의 값을 반환한다.

Parameters:
  • dateDATE 타입, TIMESTAMP 타입 또는 DATE 타입의 값.

  • fmt – 반올림할 단위에 대한 포맷을 지정. 생략되면 “dd”

Return type:

DATE

포맷, 단위, 함수의 반환 값은 다음과 같다.

포맷

단위

반환 값

‘yyyy’ 또는 ‘yy’

년도

년도로 반올림한 값

‘mm’ 또는 ‘month’

월로 반올림한 값

‘q’

사분기

사분기로 반올림하여 1/1, 4/1, 7/1, 10/1 중 하나의 날짜를 가지는 값

‘day’

date 가 있는 주의 시작 또는 다음 주에 해당하는 일요일로 반올림한 값

‘dd’

일로 반올림한 값

‘hh’

시로 반올림한 값

‘mi’

분으로 반올림한 값

‘ss’

초로 반올림한 값

SELECT ROUND(date'2012-10-26', 'yyyy');
01/01/2013
SELECT ROUND(timestamp'2012-10-26 12:10:10', 'mm');
11/01/2012
SELECT ROUND(datetime'2012-12-26 12:10:10', 'dd');
12/27/2012
SELECT ROUND(datetime'2012-12-26 12:10:10', 'day');
12/30/2012
SELECT ROUND(datetime'2012-08-26 12:10:10', 'q');
10/01/2012
SELECT TRUNC(datetime'2012-08-26 12:10:10', 'q');
07/01/2012
SELECT ROUND(datetime'2012-02-28 23:10:00', 'hh');
02/28/2012
SELECT ROUND(datetime'2012-02-28 23:58:59', 'hh');
02/29/2012
SELECT ROUND(datetime'2012-02-28 23:59:59', 'mi');
02/29/2012
SELECT ROUND(datetime'2012-02-28 23:59:59.500', 'ss');
02/29/2012

반올림이 아니라 절삭하기 위해서는 TRUNC(date, fmt) 함수를 사용하면 된다.

SEC_TO_TIME

SEC_TO_TIME(second)

SEC_TO_TIME 함수는 지정된 인자로부터 시, 분, 초를 포함한 시간을 반환한다. 인자로 0~86399 범위의 INTEGER 타입의 값을 지정할 수 있으며, TIME 타입의 값을 반환한다.

Parameters:

second – 0~86399 범위의 초

Return type:

TIME

SELECT SEC_TO_TIME(82800);
  sec_to_time(82800)
=====================
  11:00:00 PM
SELECT SEC_TO_TIME('82800.3');
  sec_to_time('82800.3')
=========================
  11:00:00 PM
SELECT SEC_TO_TIME(86399);
  sec_to_time(86399)
=====================
  11:59:59 PM

SECOND

SECOND(time)

SECOND 함수는 지정된 인자로부터 0~59 범위의 초(second)를 반환한다. 인자로 TIME, TIMESTAMP, DATETIME 타입의 값을 지정할 수 있으며, INTEGER 타입의 값을 반환한다.

Parameters:

time – 시간

Return type:

INT

SELECT SECOND('12:34:56');
   second('12:34:56')
=====================
                   56
SELECT SECOND('2010-01-01 12:34:56');
   second('2010-01-01 12:34:56')
================================
                              56
SELECT SECOND('2010-01-01 12:34:56.7890');
   second('2010-01-01 12:34:56.7890')
=====================================
                                   56

SYS_DATE, SYSDATE

SYS_DATE
SYSDATE

SYS_DATESYSDATE 는 서로 바꿔 사용할 수 있으며 서버의 현재 날짜를 DATE 타입(MM/DD/YYYY 또는 YYYY-MM-DD)으로 반환한다. 산술 연산의 단위는 일(day)이다. 현재 세션의 타임존이 서버의 타임존과 동일하면 함수는 CURDATE(), CURRENT_DATE()CURRENT_DATE 와 동일하다. 차이점은 CURDATE(), CURRENT_DATE() 를 참고하고, 함수에 대한 자세한 내용은 DBTIMEZONE(), SESSIONTIMEZONE() 을 참고한다.

입력 인자의 년, 월, 일 값이 모두 0이면 return_null_on_function_errors 시스템 파라미터에 의해 반환 값이 결정된다. 이 파라미터가 yes이면 NULL 을 반환하고 no이면 오류를 반환한다. 기본값은 no 이다.

Return type:

DATE

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'Asia/Seoul'

-- it returns the current date in DATE type

SELECT CURDATE(), CURRENT_DATE(), CURRENT_DATE, SYS_DATE, SYSDATE;

   CURRENT_DATE    CURRENT_DATE    CURRENT_DATE    SYS_DATE    SYS_DATE
========================================================================
  02/05/2016      02/05/2016      02/05/2016      02/05/2016  02/05/2016
-- it returns the date 60 days added to the current date

SELECT CURDATE()+60;

   CURRENT_DATE +60
===================
  04/05/2016
-- change session time from 'Asia/Seoul' to 'America/Los_Angeles'

SET TIME ZONE 'America/Los_Angeles';

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'America/Los_Angeles'

-- Note that CURDATE() and SYS_DATE returns different results

SELECT CURDATE(), CURRENT_DATE(), CURRENT_DATE, SYS_DATE, SYSDATE;

   CURRENT_DATE    CURRENT_DATE    CURRENT_DATE    SYS_DATE    SYS_DATE
========================================================================
  02/04/2016      02/04/2016      02/04/2016      02/05/2016  02/05/2016

Warning

10.0 이후로 SYS_DATESYSDATECURDATE (), CURRENT_DATE, CURRENT_DATE ()와 다르다. 9.x 및 그 이전 버전에서는 동일하다.

SYS_DATETIME, SYSDATETIME

SYS_DATETIME
SYSDATETIME

SYS_DATETIMESYSDATETIME 은 서로 바꿔 사용할 수 있으며 서버의 현재 날짜와 시간을 DATETIME 타입으로 반환한다. 산술연산의 단위는 밀리초(msec)이다. 현재 세션의 타임존이 서버의 타임존과 동일하면 함수는 CURRENT_DATETIME(), CURRENT_DATETIME, NOW() 와 동일하다. 차이점은 CURRENT_DATETIME(), NOW() 를 참고하고, 함수에 대한 자세한 내용은 DBTIMEZONE(), SESSIONTIMEZONE() 을 참고한다.

Return type:

DATETIME

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'Asia/Seoul'

-- it returns the current date and time in DATETIME type

SELECT NOW(), SYS_DATETIME;

   CURRENT_DATETIME               SYS_DATETIME
==============================================================
  04:05:09.292 PM 02/05/2016     04:05:09.292 PM 02/05/2016
-- it returns the timestamp value 1 hour added to the current sys_datetime value

SELECT TO_CHAR(SYSDATETIME+3600*1000, 'YYYY-MM-DD HH24:MI');

   to_char( SYS_DATETIME +3600*1000, 'YYYY-MM-DD HH24:MI')
======================
  '2016-02-05 17:05'
-- change session time from 'Asia/Seoul' to 'America/Los_Angeles'

SET TIME ZONE 'America/Los_Angeles';

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'America/Los_Angeles'

-- Note that NOW() and SYS_DATETIME return different results

SELECT NOW(), SYS_DATETIME;

   CURRENT_DATETIME               SYS_DATETIME
==============================================================
  11:08:57.041 PM 02/04/2016     04:08:57.041 PM 02/05/2016

Warning

10.0 이후로 SYS_DATEIME, SYSDATETIMECURRENT_DATETIME (), NOW ()와 다르다. 9.x 및 그 이전 버전에서는 동일하다.

SYS_TIME, SYSTIME

SYS_TIME
SYSTIME

SYS_TIMESYSTIME 은 서로 바꿔 사용할 수 있으며 서버의 현재 시간을 TIME 타입(HH:MI:SS)으로 반환한다. 산술연산의 단위는 초(sec)이다. 현재 세션의 타임존이 서버의 타임존과 동일하면 함수는 CURTIME(), CURRENT_TIME, CURRENT_TIME() 과 동일하다. 차이점은 CURTIME(), CURRENT_TIME() 을 참고하고, 함수에 대한 자세한 내용은 DBTIMEZONE(), SESSIONTIMEZONE() 을 참고한다.

Return type:

TIME

select dbtimezone(), sessiontimezone();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'Asia/Seoul'

-- it returns the current time in TIME type

SELECT CURTIME(), CURRENT_TIME(), CURRENT_TIME, SYS_TIME, SYSTIME;

   CURRENT_TIME    CURRENT_TIME    CURRENT_TIME    SYS_TIME     SYS_TIME
==========================================================================
  04:22:54 PM     04:22:54 PM     04:22:54 PM     04:22:54 PM  04:22:54 PM
-- change session time from 'Asia/Seoul' to 'America/Los_Angeles'

SET TIME ZONE 'America/Los_Angeles';

select dbtimezone(), sessiontimezone();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'America/Los_Angeles'

-- Note that CURTIME() and SYS_TIME return different results

SELECT CURTIME(), CURRENT_TIME(), CURRENT_TIME, SYS_TIME, SYSTIME;

   CURRENT_TIME    CURRENT_TIME    CURRENT_TIME    SYS_TIME     SYS_TIME
==========================================================================
  11:23:16 PM     11:23:16 PM     11:23:16 PM     04:23:16 PM  04:23:16 PM

Warning

10.0 이후로 SYS_TIME, SYSTIMECURTIME (), CURRENT_TIME ()과 다르다. 9.x 및 그 이전 버전에서는 동일하다.

SYS_TIMESTAMP, SYSTIMESTAMP

SYS_TIMESTAMP
SYSTIMESTAMP

SYS_TIMESTAMPSYSTIMESTAMP은 서로 바꿔 사용할 수 있으며 서버의 현재 날짜와 시간을 TIMESTAMP 타입으로 반환한다. 산술연산의 단위는 초(sec)이다. 현재 세션의 타임존이 서버의 타임존과 동일하면 함수는 CURRENT_TIMESTAMP, CURRENT_TIMESTAMP(), LOCALTIME, LOCALTIME(), LOCALTIMESTAMP, LOCALTIMESTAMP() 와 동일하다. 차이점은 CURRENT_TIMESTAMP, CURRENT_TIMESTAMP(), LOCALTIME, LOCALTIME(), LOCALTIMESTAMP, LOCALTIMESTAMP() 를 참고하고, 함수에 대한 자세한 내용은 DBTIMEZONE(), SESSIONTIMEZONE() 을 참고한다.

Return type:

TIMESTAMP

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'Asia/Seoul'

-- it returns the current date and time in TIMESTAMP type of session and server timezones.

SELECT LOCALTIME, SYS_TIMESTAMP;

   CURRENT_TIMESTAMP          SYS_TIMESTAMP
======================================================
  04:34:16 PM 02/05/2016     04:34:16 PM 02/05/2016
-- change session time from 'Asia/Seoul' to 'America/Los_Angeles'

SET TIME ZONE 'America/Los_Angeles';

SELECT DBTIMEZONE(), SESSIONTIMEZONE();

  dbtimezone            sessiontimezone
============================================
  'Asia/Seoul'          'America/Los_Angeles'

-- Note that LOCALTIME() and SYS_TIMESTAMP return different results

SELECT LOCALTIME, SYS_TIMESTAMP;

   CURRENT_TIMESTAMP          SYS_TIMESTAMP
======================================================
  11:34:37 PM 02/04/2016     04:34:37 PM 02/05/2016

Warning

10.0 이후로 SYS_TIMESTAMP (), SYSTIMESTAMPCURRENT_TIMESTAMP, CURRENT_TIMESTAMP (), LOCALTIME, LOCALTIME (), LOCALTIMESTAMPLOCALTIMESTAMP ()와 다르다. 9.x 및 그 이전 버전에서는 동일하다.

TIME

TIME(time)

TIME 함수는 지정된 인자로부터 시간 부분을 추출하여 ‘HH:MI:SS’ 형태의 VARCHAR 타입 문자열을 반환한다. 인자로 TIME, TIMESTAMP, DATETIME 타입의 값을 지정할 수 있다.

Parameters:

time – 시간

Return type:

STRING

SELECT TIME('12:34:56');
   time('12:34:56')
======================
  '12:34:56'
SELECT TIME('2010-01-01 12:34:56');
   time('2010-01-01 12:34:56')
======================
  '12:34:56'
SELECT TIME(datetime'2010-01-01 12:34:56');
   time(datetime '2010-01-01 12:34:56')
======================
  '12:34:56'

다음은 타임존 타입의 값을 사용하는 예이다. 타임존과 관련된 설명은 타임존이 있는 날짜/시간 데이터 타입을 참고한다.

SELECT TIME(datetimetz'1996-02-03 02:03:04 AM America/Lima PET');
'02:03:04'
SELECT TIME(datetimeltz'1996-02-03 02:03:04 AM America/Lima PET');
'16:03:04'
SELECT TIME(datetimeltz'2000-12-31 17:34:23.1234 -05:00');
'07:34:23.123'
SELECT TIME(datetimetz'2000-12-31 17:34:23.1234 -05:00');
'17:34:23.123'

TIME_TO_SEC

TIME_TO_SEC(time)

TIME_TO_SEC 함수는 지정된 인자로부터 0~86399 범위의 초를 반환한다. 인자로 TIME, TIMESTAMP, DATETIME 타입의 값을 지정할 수 있으며, INTEGER 타입의 값을 반환한다.

Parameters:

time – 시간

Return type:

INT

SELECT TIME_TO_SEC('23:00:00');
82800
SELECT TIME_TO_SEC('2010-10-04 23:00:00');
82800
SELECT TIME_TO_SEC('2010-10-04 23:00:00.1234');
82800

다음은 타임존 타입의 값을 사용하는 예이다. 타임존과 관련된 설명은 타임존이 있는 날짜/시간 데이터 타입을 참고한다.

SELECT TIME_TO_SEC(datetimeltz'1996-02-03 02:03:04 AM America/Lima PET');

57784
SELECT TIME_TO_SEC(datetimetz'1996-02-03 02:03:04 AM America/Lima PET');

7384

TIMEDIFF

TIMEDIFF(expr1, expr2)

TIMEDIFF 함수는 지정된 두 개의 시간 인자의 시간 차를 반환한다. 날짜/시간 타입인 TIME, DATE, TIMESTAMP, DATETIME 타입을 인자로 입력할 수 있으며, 두 인자의 데이터 타입은 같아야 한다. TIME 타입을 반환하며, 따라서 두 인자의 시간 차이는 00:00:00~23:59:59 범위여야 한다. 이 범위를 벗어나면 에러를 반환한다.

Parameters:

expr2 (expr1,) – 시간. 두 인자의 데이터 타입은 같아야 한다.

Return type:

TIME

SELECT TIMEDIFF(time '17:18:19', time '12:05:52');
05:12:27 AM
SELECT TIMEDIFF('17:18:19','12:05:52');
05:12:27 AM
SELECT TIMEDIFF('2010-01-01 06:53:45', '2010-01-01 03:04:05');
03:49:40 AM

다음은 타임존 타입의 값을 사용하는 예이다. 타임존과 관련된 설명은 타임존이 있는 날짜/시간 데이터 타입을 참고한다.

SELECT TIMEDIFF (datetimeltz'2013-10-28 03:11:12 AM Asia/Seoul', datetimeltz'2013-10-27 04:11:12 AM Asia/Seoul');
11:00:00 PM

TIMESTAMP

TIMESTAMP(date[, time])

TIMESTAMP 함수는 인자로 날짜/시간 형식의 문자열이 지정되고, 이를 DATETIME 타입으로 반환한다.

단일 인자로 DATE 형식 문자열(’YYYY-MM-DD’ 또는 ‘MM/DD/YYYY’) 또는 TIMESTAMP 형식 문자열(’YYYY-MM-DD HH:MI:SS’ 또는 ‘HH:MI:SS MM/DD/YYYY’)이 지정되면 이를 DATETIME 타입으로 반환한다.

두 번째 인자로 TIME 형식 문자열(’HH:MI:SS.*FF*’)이 주어지면 이를 첫 번째 인자 값에 더한 결과를 DATETIME 타입으로 반환한다. 두 번째 인자가 명시되지 않으면, 기본값으로 12:00:00.000 AM 이 설정된다.

Parameters:
  • date – ‘YYYY-MM-DD’, ‘MM/DD/YYYY’, ‘YYYY-MM-DD HH:MI:SS.*FF*’, ‘HH:MI:SS.*FF* MM/DD/YYYY’ 형식 문자열이 지정될 수 있다.

  • time – ‘HH:MI:SS*[.*FF]’ 형식 문자열이 지정될 수 있다.

Return type:

DATETIME

SELECT TIMESTAMP('2009-12-31'), TIMESTAMP('2009-12-31','12:00:00');
12:00:00.000 AM 12/31/2009     12:00:00.000 PM 12/31/2009
SELECT TIMESTAMP('2010-12-31 12:00:00','12:00:00');
12:00:00.000 AM 01/01/2011
SELECT TIMESTAMP('13:10:30 12/25/2008');
01:10:30.000 PM 12/25/2008

다음은 타임존 타입의 값에 대한 예이다. 타임존에 관련된 기술은 다음을 참조하라, see 타임존이 있는 날짜/시간 데이터 타입.

SELECT TIMESTAMP(datetimetz'2010-12-31 12:00:00 America/New_York', '03:00');
03:00:00.000 PM 12/31/2010
SELECT TIMESTAMP(datetimeltz'2010-12-31 12:00:00 America/New_York', '03:00');
05:00:00.000 AM 01/01/2011

TO_DAYS

TO_DAYS(date)

TO_DAYS 함수는 지정된 인자로부터 0년 이후의 날 수를 366~3652424 범위의 값으로 반환한다. 인자로 DATE 타입의 값을 지정할 수 있으며, INTEGER 타입의 값을 반환한다.

TO_DAYS 함수는 그레고리력(Gregorian Calendar) 출현(1582년)보다 앞의 날짜는 고려하지 않았으므로, 1582년보다 앞의 날짜에 대해서는 사용하지 않는 것을 권장한다.

Parameters:

date – 날짜

Return type:

INT

SELECT TO_DAYS('2010-10-04');
   to_days('2010-10-04')
========================
                  734414
SELECT TO_DAYS('2010-10-04 12:34:56');
   to_days('2010-10-04 12:34:56')
================================
                          734414
SELECT TO_DAYS('2010-10-04 12:34:56.7890');
   to_days('2010-10-04 12:34:56.7890')
======================================
                                734414
SELECT TO_DAYS('1-1-1');
   to_days('1-1-1')
===================
                366
SELECT TO_DAYS('9999-12-31');
   to_days('9999-12-31')
========================
                 3652424

TRUNC

TRUNC(date[, fmt])

fmt 에서 지정한 단위 아래의 값을 절삭한다. DATE 타입의 값을 반환한다.

Parameters:
  • dateDATE 타입, TIMESTAMP 타입 또는 DATETIME 타입의 값

  • fmt – 절삭할 단위에 대한 포맷을 지정. 생략되면 “dd”

Return type:

DATE

포맷, 단위, 함수의 반환 값은 다음과 같다.

포맷

단위

함수의 반환 값

‘yyyy’ 또는 ‘yy’

년도

같은 년도 1월 1일

‘mm’ 또는 ‘month’

같은 월의 1일

‘q’

사분기

사분기의 첫째날 (1/1, 4/1, 7/1, 10/1)

‘day’

date 가 있는 주의 시작에 해당하는 일요일

‘dd’

입력 값과 같은 날짜

SELECT TRUNC(date'2012-12-26', 'yyyy');
01/01/2012
SELECT TRUNC(timestamp'2012-12-26 12:10:10', 'mm');
12/01/2012
SELECT TRUNC(datetime'2012-12-26 12:10:10', 'q');
10/01/2012
SELECT TRUNC(datetime'2012-12-26 12:10:10', 'dd');
12/26/2012
// It returns the date of Sunday of the week which includes date'2012-12-26'
SELECT TRUNC(datetime'2012-12-26 12:10:10', 'day');
12/23/2012

절삭이 아니라 반올림하기 위해서는 ROUND(date, fmt) 함수를 사용하면 된다.

TZ_OFFSET

TZ_OFFSET(timezone_string)

타임존 오프셋 또는 타임존 지역 이름(예: ‘-05:00’ 또는 ‘Europe/Vienna’)으로부터 타임존 오프셋을 반환한다.

Parameters:

timezone_string – 타임존 오프셋 또는 타임존 지역 이름

Return type:

STRING

SELECT TZ_OFFSET('+05:00');
'+05:00'
SELECT TZ_OFFSET('Asia/Seoul');
'+09:00'

타임존과 관련된 설명은 타임존이 있는 날짜/시간 데이터 타입을 참고한다.

UNIX_TIMESTAMP

UNIX_TIMESTAMP([date])

UNIX_TIMESTAMP 함수는 인자를 생략할 수 있으며, 인자를 생략하면 ‘1970-01-01 00:00:00’ UTC 이후 현재 시스템 날짜/시간까지의 초 단위 시간 간격(interval)을 반환한다. date 인자가 지정되면 ‘1970-01-01 00:00:00’ UTC 이후 지정된 날짜/시간까지의 초 단위 시간 간격을 반환한다.

년, 월, 일에 해당하는 인자 값에는 0이 허용되지 않지만 날짜 및 시간에 해당하는 모든 인자 값에 0을 입력한 경우에는 예외적으로 0이 반환된다.

DATETIME 타입의 인자는 세션 타임존에서 고려한다.

Parameters:

dateDATE 타입, TIMESTAMP 타입, TIMESTAMPTZ 타입, TIMESTAMPLTZ 타입, DATETIME 타입, DATETIMETZ 타입, DATETIMELTZ 타입, DATE 형식 문자열(’YYYY-MM-DD’ 또는 ‘MM/DD/YYYY’), TIMESTAMP 형식 문자열(’YYYY-MM-DD HH:MI:SS’, ‘HH:MI:SS MM/DD/YYYY’) 또는 ‘YYYYMMDD’ 형식 문자열을 지정할 수 있다.

Return type:

INT

SELECT UNIX_TIMESTAMP('1970-01-02'), UNIX_TIMESTAMP();
   unix_timestamp('1970-01-02')   unix_timestamp()
==================================================
                          54000         1270196737
SELECT UNIX_TIMESTAMP ('0000-00-00 00:00:00');
   unix_timestamp('0000-00-00 00:00:00')
========================================
                                       0
 -- when used without argument, it returns the exact value at the moment of execution of each occurence
 SELECT  UNIX_TIMESTAMP(), SLEEP(1), UNIX_TIMESTAMP();

   unix_timestamp()     sleep(1)   unix_timestamp()
===================================================
         1454661297            0         1454661298

UTC_DATE

UTC_DATE()

UTC_DATE 함수는 UTC 날짜를 ‘YYYY-MM-DD’ 형태로 반환한다.

Return type:

STRING

SELECT UTC_DATE();
  utc_date()
==============
  01/12/2011

UTC_TIME

UTC_TIME()

UTC_TIME 함수는 UTC 시간을 ‘HH:MI:SS’ 형태로 반환한다.

Return type:

STRING

SELECT UTC_TIME();
  utc_time()
==============
  10:35:52 AM

WEEK

WEEK(date[, mode])

WEEK 함수는 지정된 인자로부터 0~53 범위의 주를 반환한다. 인자로 DATE, TIMESTAMP, DATETIME 타입의 값을 지정할 수 있으며, INTEGER 타입의 값을 반환한다.

Parameters:
  • date – 날짜

  • mode – 0~7 범위의 값

Return type:

INT

함수의 두 번째 인자인 mode 는 생략할 수 있으며, 0~7 범위의 값을 입력한다. 이 값으로 한 주가 일요일부터 시작하는지 월요일부터 시작하는지, 리턴 값의 범위가 0~53인지 1~53인지 설정한다. mode 를 생략하면 시스템 파라미터 default_week_format 의 값(기본값: 0)이 사용된다. mode 값의 의미는 다음과 같다.

mode

시작 요일

범위

해당 연도의 첫 번째 주

0

일요일

0~53

일요일이 해당 연도에 속하는 첫 번째 주

1

월요일

0~53

3일 이상이 해당 연도에 속하는 첫 번째 주

2

일요일

1~53

일요일이 해당 연도에 속하는 첫 번째 주

3

월요일

1~53

3일 이상이 해당 연도에 속하는 첫 번째 주

4

일요일

0~53

3일 이상이 해당 연도에 속하는 첫 번째 주

5

월요일

0~53

월요일이 해당 연도에 속하는 첫 번째 주

6

일요일

1~53

3일 이상이 해당 연도에 속하는 첫 번째 주

7

월요일

1~53

월요일이 해당 연도에 속하는 첫 번째 주

mode 값이 0, 1, 4, 5 중 하나이고 해당 날짜보다 앞선 연도의 마지막 주에 해당하면 WEEK 함수는 0을 반환한다. 이때의 목적은 해당 연도에서 해당 주가 몇 번째 주인지를 아는 것이므로, 1999년의 52번째 주에 해당해도 2000년의 날짜가 0번째 주에 해당되는 0을 반환한다.

SELECT YEAR('2000-01-01'), WEEK('2000-01-01',0);
   year('2000-01-01')   week('2000-01-01', 0)
=============================================
                2000                       0

시작 요일이 속해있는 주의 연도를 기준으로 해당 날짜가 몇 번째 주인지 알려면, mode 값으로 0, 2, 5, 7 중 하나의 값을 사용한다.

SELECT WEEK('2000-01-01',2);
    week('2000-01-01', 2)
========================
                      52
SELECT WEEK('2010-04-05');
   week('2010-04-05', 0)
========================
                      14
SELECT WEEK('2010-04-05 12:34:56',2);
   week('2010-04-05 12:34:56',2)
===============================
                              14
SELECT WEEK('2010-04-05 12:34:56.7890',4);
   week('2010-04-05 12:34:56.7890',4)
====================================
                                  14

WEEKDAY

WEEKDAY(date)

WEEKDAY 함수는 지정된 인자로부터 0~6 범위의 요일(0: 월요일, 1: 화요일, …, 6: 일요일)을 반환한다. 인자로 DATE, TIMESTAMP, DATETIME 타입의 값을 지정할 수 있으며, INTEGER 타입의 값을 반환한다.

Parameters:

date – 날짜

Return type:

INT

SELECT WEEKDAY('2010-09-09');
   weekday('2010-09-09')
========================
                       3
SELECT WEEKDAY('2010-09-09 13:16:00');
   weekday('2010-09-09 13:16:00')
=================================
                                3

YEAR

YEAR(date)

YEAR 함수는 지정된 인자로부터 1~9999 범위의 연도를 반환한다. 인자로 DATE, TIMESTAMP, DATETIME 타입의 값을 지정할 수 있으며, INTEGER 타입의 값을 반환한다.

Parameters:

date – 날짜

Return type:

INT

SELECT YEAR('2010-10-04');
   year('2010-10-04')
=====================
                 2010
SELECT YEAR('2010-10-04 12:34:56');
   year('2010-10-04 12:34:56')
==============================
                          2010
SELECT YEAR('2010-10-04 12:34:56.7890');
   year('2010-10-04 12:34:56.7890')
===================================
                               2010