| - DAYOFWEEK(date) : 해당 날짜의 요일을 숫자로 반환한다. 일요일은 1, 토요일은 7 이다. - 예 : select DAYOFWEEK('1998-02-03');
- WEEKDAY(date) : 해당 날짜에 대한 요일을 반환한다. 월요일은 0, 일요일은 6 이다. - 예 : select WEEKDAY('1997-10-04 22:23:00');
- DAYOFYEAR(date) : 해당 날짜의 1월 1일부터의 날수를 반환한다. 결과값은 1에서 366 까지이다. - 예 : select DAYOFYEAR('1998-02-03');
- YEAR(date) : 해당 날짜의 년을 반환한다. - 예 : select YEAR('98-02-03');
- MONTH(date) : 해당 날짜의 월을 반환한다. - 예 : select MONTH('1998-02-03');
- DAYOFMONTH(date) : 해당 날짜의 일을 반환한다. 결과값은 1 에서 31 까지이다. - 예 : select DAYOFMONTH('1998-02-03');
- HOUR(time) : 해당날짜의 시간을 반환한다. 결과값은 0 에서 23 이다. - 예 : select HOUR('10:05:03');
- MINUTE(time) : 해당날짜의 분을 반환한다. 결과값은 0 에서 59 이다. - 예 : select MINUTE('98-02-03 10:05:03');
- SECOND(time) : 해당날짜의 초를 반환한다. 결과값은 0 에서 59 이다. - 예 : select SECOND('10:05:03');
- DAYNAME(date) : 해당 날짜의 요일 이름을 반환한다. 일요일은 'Sunday' 이다. - 예 : select DAYNAME("1998-02-05");
- MONTHNAME(date) : 해당 날짜의 월 이름을 반환한다. 2월은 'February' 이다. - 예 : select MONTHNAME("1998-02-05");
- QUARTER(date) : 해당 날짜의 분기를 반환한다. 결과값은 1 에서 4 이다.
- WEEK(date,first) : 1월 1일부터 해당날가지의 주 수를 반환한다. 주의 시작을 일요일부터 할경우는 두번째 인자를 0, 월요일부터 시작할 경우는 1 을 넣는다. 결과값은 1 에서 52 이다. - 예 : select WEEK('1998-02-20',1);
- PERIOD_ADD(P,N) : P (형식은 YYMM 또는 YYYYMM 이어야 한다.) 에 N 만큼의 달 수를 더한값을 반환한다. 주의할것은 두번째 인자는 숫자라는 것이다. - 예 : select PERIOD_ADD(9801,2);
- PERIOD_DIFF(P1,P2) : 두개의 인자 사이의 달 수를 반환한다. 두개의 인자 모두 형식은 YYMM 또는 YYYYMM 이어야 한다.
- DATE_ADD(date,INTERVAL expr type) : 날짜를 더한 날짜를 반환한다. - DATE_SUB(date,INTERVAL expr type) : 날짜를 뺀 날짜를 반환한다. - ADDDATE(date,INTERVAL expr type) : DATE_ADD(date,INTERVAL expr type) 와 동일하다. - SUBDATE(date,INTERVAL expr type) : DATE_SUB(date,INTERVAL expr type) 와 동일하다. - EXTRACT(type FROM date) : 날짜에서 해당 부분을 추출한다. - 예 : SELECT DATE_ADD("1997-12-31 23:59:59", INTERVAL 1 SECOND); SELECT DATE_ADD("1997-12-31 23:59:59", INTERVAL 1 DAY); SELECT DATE_ADD("1997-12-31 23:59:59", INTERVAL "1:1" MINUTE_SECOND); SELECT DATE_SUB("1998-01-01 00:00:00", INTERVAL "1 1:1:1" DAY_SECOND); SELECT DATE_ADD("1998-01-01 00:00:00", INTERVAL "-1 10" DAY_HOUR); SELECT DATE_SUB("1998-01-02", INTERVAL 31 DAY); SELECT EXTRACT(YEAR FROM "1999-07-02"); SELECT EXTRACT(YEAR_MONTH FROM "1999-07-02 01:02:03"); SELECT EXTRACT(DAY_MINUTE FROM "1999-07-02 01:02:03"); - 참고 : type 에 사용되는 키워드는 SECOND, MINUTE, HOUR, DAY, MONTH, YEAR, MINUTE_SECOND, HOUR_MINUTE, DAY_HOUR, YEAR_MONTH, HOUR_SECOND, DAY_MINUTE, DAY_SECOND 이다. - 주의 : 계산한 달의 날수가 작을 경우는 해당달의 마지막 날을 반환한다. 예를 들어 select DATE_ADD('1998-01-30', Interval 1 month); 의 경우 1998-02-28 을 반환한다.
- TO_DAYS(date) : 0 년 부터의 날짜수를 반환한다. 이 함수는 1582 이전 날에 대해서는 계산하지 않는다. - 예 : select TO_DAYS(950501);
- FROM_DAYS(N) : 해당 숫자만큼의 날짜를 반환한다. 이 함수는 1582 이전 날에 대해서는 계산하지 않는다. - 예 : select FROM_DAYS(729669);
- DATE_FORMAT(date,format) : 날짜를 해당 형식의 문자열로 변환하여 반환한다. - 예 : select DATE_FORMAT('1997-10-04 22:23:00', '%W %M %Y'); select DATE_FORMAT('1997-10-04 22:23:00', '%H:%i:%s'); select DATE_FORMAT('1997-10-04 22:23:00', '%D %y %a %d %m %b %j'); select DATE_FORMAT('1997-10-04 22:23:00', '%H %k %I %r %T %S %w'); - 참고 : 형식은 다음과 같다. %M (달 이름), %W (요일 이름), %Y (YYYY 형식의 년도), %y (YY 형식의 년도), %a (요일 이름의 약자), %d (DD 형식의 날짜), %e (D 형식의 날짜), %m (MM 형식의 날짜), %c (M 형식의 날짜), %H (HH 형식의 시간, 24시간 형식), %k (H 형식의 시간, 24시간 형식), %h (HH 형식의 시간, 12시간 형식), %i (MM 형식의 분), %p (AM 또는 PM)
- TIME_FORMAT(time,format) : DATE_FORMAT(date,format) 과 같은 방식으로 사용할수 있으나 날 이상의 것에 대해서는 NULL 이나 0 을 반환한다.
- CURDATE() : 현재날짜를 반환한다. 숫자와 연산을 할경우 숫자로 변환된다. 형식은 'YYYY-MM-DD' 또는 YYYYMMDD 이다. - 예 : select CURDATE(); select CURDATE() + 0;
- CURTIME() : 현재시간을 반환한다. 숫자와 연산을 할경우 숫자로 변환된다. 형식은 'HH:MM:SS' 또는 HHMMSS 이다. - 예 : select CURTIME(); select CURTIME() + 0;
- SYSDATE() : 현재날짜시간을 반환한다. 숫자와 연산을 할경우 숫자로 변환된다. 형식은 'YYYY-MM-DD HH:MM:SS' 또는 YYYYMMDDHHMMSS 이다. - 예 : select NOW(); select NOW() + 0;
- NOW() : SYSDATE() 와 동일하다.
- UNIX_TIMESTAMP() : '1970-01-01 00:00:00' 부터의 초를 반환한다. 인자가 주어질 경우는 해당 날짜에 대한 유닉스 시간을 반환한다. - 예 : select UNIX_TIMESTAMP(); select UNIX_TIMESTAMP('1997-10-04 22:23:00');
- FROM_UNIXTIME(unix_timestamp) : 유닉스시간에서 날짜 형식으로 변환한다. - 예 : select FROM_UNIXTIME(875996580);
- FROM_UNIXTIME(unix_timestamp,format) : 유닉스시간을 날짜형식으로 변환하고 DATE_FORMAT(date,format) 에서 설명한 포맷으로 변환하여 반환한다. - 예 : select FROM_UNIXTIME(UNIX_TIMESTAMP(), '%Y %D %M %h:%i:%s %x');
- TIME_TO_SEC(time) : 해당 시간의 0:0:0 에서부터의 초를 반환한다. - 예 : select TIME_TO_SEC('22:23:00');
- SEC_TO_TIME(seconds) : 초를 시간으로 바꾼다. - 예 : select SEC_TO_TIME(2378);
|
출처 - http://selfesteem.tistory.com/7
===================================================================================
날짜 및 시간 더하기/빼기
한달전 where reg_date >= date_add(now(), interval -1 month)
하루전 where reg_date >= date_add(now(), interval -1 day)
한시간전 where reg_date >= date_add(now(), interval -1 hour)
===================================================================================
select와 where절에서 사용되는 함수
group 함수
DATEOFWEEK(date) : 날짜에 대한 요일을 정수로 반환한다,
1=일요일, 2=월요일, 7=토요일을 의미한다.
【예제】
mysql> SELECT DAYOFWEEK(CURDATE()), DAYOFWEEK('2007-11-12');
+----------------------+-------------------------+
| DAYOFWEEK(CURDATE()) | DAYOFWEEK('2007-11-12') |
+----------------------+-------------------------+
| 2 | 2 |
+----------------------+-------------------------+
WEEKDAY(date) : date에 대한 요일을 반환한다.
0=월요일,....,6=일요일을 의미한다.
【예제】
mysql> SELECT WEEKDAY(CURDATE()), WEEKDAY('2007-11-12');
+--------------------+-----------------------+
| WEEKDAY(CURDATE()) | WEEKDAY('2007-11-12') |
+--------------------+-----------------------+
| 0 | 0 |
+--------------------+-----------------------+
DAYOFMONTH(date) : 날짜 date에 대한 월중 값을 1∼31범위에서 반환한다.
【예제】
mysql> SELECT DAYOFMONTH(CURDATE()),DAYOFMONTH('2007-11-12');
+-----------------------+--------------------------+
| DAYOFMONTH(CURDATE()) | DAYOFMONTH('2007-11-12') |
+-----------------------+--------------------------+
| 12 | 12 |
+-----------------------+--------------------------+
DAYOFYEAR(date) : 날짜 date에 대한 년중 값을 1∼366범위에서 반환한다.
【예제】
mysql> SELECT DAYOFYEAR(CURDATE()), DAYOFYEAR('2007-11-12');
+----------------------+-------------------------+
| DAYOFYEAR(CURDATE()) | DAYOFYEAR('2007-11-12') |
+----------------------+-------------------------+
| 316 | 316 |
+----------------------+-------------------------+
MONTH(date) : date값을 1∼12월로 반환한다.
【예제】
mysql> SELECT MONTH(CURDATE()), MONTH('2007-11-12');
+------------------+---------------------+
| MONTH(CURDATE()) | MONTH('2007-11-12') |
+------------------+---------------------+
| 11 | 11 |
+------------------+---------------------+
DAYNAME(date) : 날짜 date의 요일을 반환한다.
【예제】
mysql> SELECT DAYNAME(CURDATE()),DAYNAME('2007-11-12');
+--------------------+-----------------------+
| DAYNAME(CURDATE()) | DAYNAME('2007-11-12') |
+--------------------+-----------------------+
| Monday | Monday |
+--------------------+-----------------------+
MONTHNAME(date) : 날짜 date의 달(월)을 반환한다.
【예제】
mysql> SELECT MONTHNAME(CURDATE()),MONTHNAME('2007-11-12');
+----------------------+-------------------------+
| MONTHNAME(CURDATE()) | MONTHNAME('2007-11-12') |
+----------------------+-------------------------+
| November | November |
+----------------------+-------------------------+
QUARTER(date) : 날짜 date의 분기 값을 1∼4로 반환한다.
【예제】
mysql> SELECT QUARTER(CURDATE()),QUARTER('2007-11-12');
+--------------------+-----------------------+
| QUARTER(CURDATE()) | QUARTER('2007-11-12') |
+--------------------+-----------------------+
| 4 | 4 |
+--------------------+-----------------------+
WEEK(date)
WEEK(date,first) : 날짜 date의 1년 중 주값으로 1∼53범위 내에서 반환하며,
week(date)는 일요일부터 시작하지만,
week(date,first)는 일요일부터 시작(first=0)하는 경우나
월요일부터 시작하는 경우(first=1)처럼 지정할 수 있다.
【예제】
mysql> SELECT WEEK(CURDATE()),WEEK('2007-11-12');
+-----------------+--------------------+
| WEEK(CURDATE()) | WEEK('2007-11-12') |
+-----------------+--------------------+
| 45 | 45 |
+-----------------+--------------------+
mysql> SELECT WEEK(CURDATE(),0), WEEK(CURDATE(),1);
+-------------------+-------------------+
| WEEK(CURDATE(),0) | WEEK(CURDATE(),1) |
+-------------------+-------------------+
| 45 | 46 |
+-------------------+-------------------+
YEAR(date) : 날짜 date를 년으로 1000∼9999범위에서 반환한다.
【예제】
mysql> SELECT YEAR(CURDATE()),YEAR('2007-11-12');
+-----------------+--------------------+
| YEAR(CURDATE()) | YEAR('2007-11-12') |
+-----------------+--------------------+
| 2007 | 2007 |
+-----------------+--------------------+
YEARWEEK(date)
YEARWEEK(date,first) : 날짜 date에 대한 년과 달을 반환하며,
first의 경우는 week(date,first)의 사용법이 같다.
【예제】
mysql> SELECT YEARWEEK(CURDATE()),YEARWEEK('2007-11-12');
+---------------------+------------------------+
| YEARWEEK(CURDATE()) | YEARWEEK('2007-11-12') |
+---------------------+------------------------+
| 200745 | 200745 |
+---------------------+------------------------+
mysql> SELECT YEARWEEK(CURDATE()), YEARWEEK(CURDATE(),1);
+---------------------+-----------------------+
| YEARWEEK(CURDATE()) | YEARWEEK(CURDATE(),1) |
+---------------------+-----------------------+
| 200745 | 200746 |
+---------------------+-----------------------+
HOUR(time)
MINUTE(time)
SECOND(time) : 입력값 time을 시, 분, 초로 반환한다.
【예제】
mysql> SELECT HOUR(CURDATE()),MINUTE(CURDATE()),SECOND(CURDATE());
+-----------------+-------------------+-------------------+
| HOUR(CURDATE()) | MINUTE(CURDATE()) | SECOND(CURDATE()) |
+-----------------+-------------------+-------------------+
| 0 | 20 | 7 |
+-----------------+-------------------+-------------------+
PERIOD_ADD(p,n) : YYMM이나 YYYYMM으로 표시되는 기간 p에 n 개월을 더한다.
【예제】
mysql> SELECT PERIOD_ADD(200745,3);
+----------------------+
| PERIOD_ADD(200745,3) |
+----------------------+
| 201012 |
+----------------------+
PERIOD_DIFF(p1,p2) : YYMM이나 YYYYMM으로 표기되는 p1과 p2의 차이 개월을 반환 한다.
【예제】
mysql> SELECT PERIOD_DIFF(200207,0107);
+--------------------------+
| PERIOD_DIFF(200207,0107) |
+--------------------------+
| 12 |
+--------------------------+
DATE_ADD(date,INTERVAL expr type)
DATE_SUB(date,INTERVAL expr type)
ADDDATE(date,INTERVAL expr type)
SUBDATE(date,INTERVAL expr type) :
날짜 date에 type 형식으로 지정한 expr값을 더하거나 뺀다.
DATE_ADD()와 ADDDATE()는 같은 동작이고,
DATE_SUB()와 SUBDATE()는 같은 의미이다.
여기서 표현되는 type, expr 형식은 다음과 같다.
SECOND | SECONDS |
MINUTE | MINUTES |
HOUR | HOURS |
DAY | DAYS |
MONTH | MONTHS |
YEAR | YEARS |
MINUTE_SECOND | "MINUTES:SECONDS" |
HOUR_MINUTE | "HOURS:MINUTES" |
DAY_HOUR | "DAYS HOURS" |
YEAR_MONYH | "YEARS-MONTHS" |
HOUR_SECOND | "HOURS:MINUTES:SECONDS" |
DAY_MINUTE | "DAYS HOURS:MINUTES" |
DAY_SECOND | "DAYS HOURS:MINUTES:SECONDS" |
|
【예제】
mysql>
SELECT DATE_ADD('2007-12-31 23:59:59', INTERVAL 1 SECOND);
+----------------------------------------------------+
| DATE_ADD('2007-12-31 23:59:59', INTERVAL 1 SECOND) |
+----------------------------------------------------+
| 2008-01-01 00:00:00 |
+----------------------------------------------------+
EXTRACT(type FROM date) : 이 함수는 DATE_ADD(), DATE_SUB()와 같이 원하는 부분을 추출한다.
【예제】
mysql>
SELECT EXTRACT(YEAR FROM '2007-11-12');
+---------------------------------+
| EXTRACT(YEAR FROM '2007-11-12') |
+---------------------------------+
| 2007 |
+---------------------------------+
mysql>
SELECT EXTRACT(YEAR_MONTH FROM '2007-11-12 01:22:33');
+------------------------------------------------+
| EXTRACT(YEAR_MONTH FROM '2007-11-12 01:22:33') |
+------------------------------------------------+
| 200711 |
+------------------------------------------------+
mysql>
SELECT EXTRACT(DAY_MINUTE FROM '2007-11-12 01:22:33');
+------------------------------------------------+
| EXTRACT(DAY_MINUTE FROM '2007-11-12 01:22:33') |
+------------------------------------------------+
| 120122 |
+------------------------------------------------+
TO_DAYS(date) : 입력된 date값에 대한 0년을 기준으로 한 날짜 수를 반환한다.
【예제】
mysql>
SELECT TO_DAYS(NOW());
+----------------+
| TO_DAYS(NOW()) |
+----------------+
| 733357 |
+----------------+
FROM_DAYS(n) : 입력된 날짜 수 n에 대한 연월일을 반환한다.
【예제】
mysql>
select from_days('733357');
+---------------------+
| from_days('733357') |
+---------------------+
| 2007-11-12 |
+---------------------+
mysql>
select from_days(to_days(now()));
+---------------------------+
| from_days(to_days(now())) |
+---------------------------+
| 2007-11-12 |
+---------------------------+
DATE_FORMAT(date,format) : 입력된 date를 format 형식으로 반환한다.
사용되는 format 형식은 다음과 같다.
%M | 영문 달 이름(January...December) |
%W | 요일명(Sunday...Saterday) |
%D | 날짜의 서수표기(1st,2nd,3rd....) |
%Y | 4자리 년표기 |
%y | 2자리 년표기 |
%X | 일요일부터 시작하는 주수를 4자리로 표기 |
%x | 월요일부터 시작하는 주수를 4자리로 표기 |
%a | 단축된 요일명 표기(Sun...Sat) |
%d | 월중 날짜를 숫자로 표기(00...31) |
%e | 월중 날짜를 숫자로 표기(0...31) |
%m | 숫자로 표기된 월(01...12) |
%c | 숫자로 표기된 월(1...12) |
%b | 단축된 달 이름 표기(Jan...Dec) |
%j | 년중 일수 표기(001...366) |
%H | 24시간 표기(00...23) |
%k | 24시간 표기(0...23) |
%h | 12시간 표기(01...12) |
%I | 12시간 표기(01...12) |
%l | 12시간 표기(1...12) |
%i | 분의 숫자 표기(00...59) |
%r | 12시간 표기(hh:mm:ss [AP]M) |
%T | 24시간 표기(hh:mm:ss) |
%S | 초 표기(00...59) |
%s | 초 표기(00...59) |
%p | AM 또는 PM |
%w | 요일을 숫자로 표기(0=일요일...6=토요일) |
%U | 일요일부터 시작하는 수준 표기(0...53) |
%u | 월요일부터 시작하는 수준 표기(0...53) |
%V | 일요일부터 시작하는 수준 표기(1...53) |
%v | 월요일부터 시작하는 수준 표기(1...53) |
%% | % 문자 표기 |
|
【예제】
mysql>
SELECT DATE_FORMAT(CURDATE(),'%W %M %Y');
+-----------------------------------+
| DATE_FORMAT(CURDATE(),'%W %M %Y') |
+-----------------------------------+
| Monday November 2007 |
+-----------------------------------+
mysql>
SELECT DATE_FORMAT(CURDATE(),'%Y.%m.%d');
+-----------------------------------+
| DATE_FORMAT(CURDATE(),'%Y.%m.%d') |
+-----------------------------------+
| 2007.11.12 |
+-----------------------------------+
TIME_FORMAT(time,format) : 이 함수는 DATE_FORMAT() 함수처럼 쓰이지만,
format은 시분초만 지정한다.
【예제】
mysql>
select time_format(curtime(), '%r');
+------------------------------+
| time_format(curtime(), '%r') |
+------------------------------+
| 09:29:40 AM |
+------------------------------+
CURDATE()
CURRENT_DATE : 오늘 날짜를 YYYY-MM-DD나 YYYYMMDD 형식으로 반환한다.
【예제】
mysql>
SELECT CURDATE(),CURRENT_DATE;
+------------+--------------+
| CURDATE() | CURRENT_DATE |
+------------+--------------+
| 2007-11-12 | 2007-11-12 |
+------------+--------------+
CURTIME()
CURRENT_TIME : 현재 시각을 HH:MM:SS나 HHMMSS 형식으로 반환한다.
【예제】
mysql>
SELECT CURTIME(),CURRENT_TIME;
+-----------+--------------+
| CURTIME() | CURRENT_TIME |
+-----------+--------------+
| 14:31:51 | 14:31:51 |
+-----------+--------------+
NOW()
SYSDATE()
CURRENT_TIMESTAMP : 오늘 현시각을 YYYY-MM-DD HH:MM:SS나 YYYYMMDDHHMMSS 형식으로 반환한다.
【예제】
mysql>
SELECT NOW(),SYSDATE(),CURRENT_TIMESTAMP;
+---------------------+---------------------+---------------------+
| NOW() | SYSDATE() | CURRENT_TIMESTAMP |
+---------------------+---------------------+---------------------+
| 2007-11-12 09:33:38 | 2007-11-12 09:33:38 | 2007-11-12 09:33:38 |
+---------------------+---------------------+---------------------+
UNIX_TIMESTAMP()
UNIX_TIMESTAMP(date) : 입력으로 주어진 날짜를 1970-01-01 00:00:00부터 계산한 시간값을 반환한다.
【예제】
mysql>
SELECT UNIX_TIMESTAMP(),UNIX_TIMESTAMP(CURDATE());
+------------------+---------------------------+
| UNIX_TIMESTAMP() | UNIX_TIMESTAMP(CURDATE()) |
+------------------+---------------------------+
| 1194827645 | 1194793200 |
+------------------+---------------------------+
FROM_UNIXTIME(unix_timestamp[,format]) : unix_timestamp 값을 DATE_FORMAT()과 같은 형태로 반환한다.
unix_timestamp 값을 YYYY-MM-DD HH:MM:SS나 YYYYMMDDHHMMSS 형태로 반환한다.
【예제】
mysql>
SELECT FROM_UNIXTIME(UNIX_TIMESTAMP(),'%Y.%d.%m');
+--------------------------------------------+
| FROM_UNIXTIME(UNIX_TIMESTAMP(),'%Y.%d.%m') |
+--------------------------------------------+
| 2007.12.11 |
+--------------------------------------------+
mysql>
SELECT FROM_UNIXTIME(UNIX_TIMESTAMP());
+---------------------------------+
| FROM_UNIXTIME(UNIX_TIMESTAMP()) |
+---------------------------------+
| 2007-11-12 09:35:02 |
+---------------------------------+
SEC_TO_TIME(seconds)
TIME_TO_SEC(time) : 입력한 time을 초단위 변환한다.
【예제】
mysql>
SELECT TIME_TO_SEC(CURTIME()), SEC_TO_TIME(CURTIME());
+------------------------+------------------------+
| TIME_TO_SEC(CURTIME()) | SEC_TO_TIME(CURTIME()) |
+------------------------+------------------------+
| 34530 | 25:58:50 |
+------------------------+------------------------+
출처 - http://jinpo.kunsan.ac.kr/lecture/mysql/day_time_function.html