[MySQL] MySQL 날짜 관련 함수
MySQL 날짜 관련 함수
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');
select fieldname form tablename where FROM_UNIXTIME(wdate, '%Y%m') = '$dateyear.$datemonth';
일자별로 통계를 구할때 유닉스 타임을 변경하여 처리하는 간단한 예제
$s_day = "20230301";
$e_day = "20230328";
// 일자별 참여한 아이디수 및 컨텐츠수
$query = "
SELECT FROM_UNIXTIME( created_at, '%Y%m%d' ) as date, count(distinct user_id) as count_mem, count(*) as count_post
FROM TABLE_NAME
WHERE FROM_UNIXTIME( created_at, '%Y%m%d' ) >= '$s_day' and
FROM_UNIXTIME( created_at, '%Y%m%d' ) <= '$e_day'
$addquery
group by FROM_UNIXTIME( created_at, '%Y%m%d' )
order by created_at DESC
";
// 총 참여자수 및 총 콘텐츠수
$query = "
SELECT count(distinct user_id) as count_mem, count(*) as count_post
FROM TABLE_NAME
WHERE FROM_UNIXTIME( created_at, '%Y%m%d' ) >= '$s_day' and
FROM_UNIXTIME( created_at, '%Y%m%d' ) <= '$e_day'
$addquery
order by created_at DESC
";
TIME_TO_SEC(time)
해당 시간의 0:0:0 에서부터의 초를 반환한다.
select TIME_TO_SEC('22:23:00');
SEC_TO_TIME(seconds)
초를 시간으로 바꾼다.
select SEC_TO_TIME(2378);
Table of contents 목차
- MySQL 날짜 관련 함수
- DAYOFWEEK(date)
- WEEKDAY(date)
- DAYOFYEAR(date)
- YEAR(date)
- MONTH(date)
- DAYOFMONTH(date)
- HOUR(time)
- MINUTE(time)
- SECOND(time)
- DAYNAME(date)
- MONTHNAME(date)
- QUARTER(date)
- WEEK(date,first)
- PERIOD_ADD(P,N)
- PERIOD_DIFF(P1,P2)
- DATE_ADD(date,INTERVAL expr type)
- DATE_SUB(date,INTERVAL expr type)
- ADDDATE(date,INTERVAL expr type)
- SUBDATE(date,INTERVAL expr type)
- EXTRACT(type FROM date)
- TO_DAYS(date)
- FROM_DAYS(N)
- DATE_FORMAT(date,format)
- TIME_FORMAT(time,format)
- CURDATE()
- CURTIME()
- SYSDATE()
- NOW()
- UNIX_TIMESTAMP()
- FROM_UNIXTIME(unix_timestamp)
- FROM_UNIXTIME(unix_timestamp,format)
- TIME_TO_SEC(time)
- SEC_TO_TIME(seconds)