ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [MySQL] 날짜 함수 및 날짜 변환
    MySQL 2020. 3. 31. 19:28

    출처 : https://linuxism.ustd.ip.or.kr/850

     

    mysql - 날짜 함수 및 날짜 변환

    - DAYOFWEEK(date) : 해당 날짜의 요일을 숫자로 반환한다. 일요일은 1, 토요일은 7 이다. - 예 : select DAYOFWEEK('1998-02-03'); - WEEKDAY(date) : 해당 날짜에 대한 요일을 반환한다. 월요일은 0, 일요일은 6..

    linuxism.ustd.ip.or.kr

     

    - 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);

    'MySQL' 카테고리의 다른 글

    테이블 생성 당시의 쿼리 다시 보기  (0) 2020.05.21
    mySQL 명령어  (0) 2020.05.19
    [MySQL] case문  (0) 2020.03.31
    [MySQL] DB 생성  (0) 2020.03.05

    댓글

Designed by Tistory.