>  기사  >  데이터 베이스  >  MySQL에서 일반적으로 사용되는 날짜 관련 함수에 대해 이야기해 보겠습니다.

MySQL에서 일반적으로 사용되는 날짜 관련 함수에 대해 이야기해 보겠습니다.

coldplay.xixi
coldplay.xixi앞으로
2021-02-20 09:15:351884검색

MySQL에서 일반적으로 사용되는 날짜 관련 함수에 대해 이야기해 보겠습니다.

추천 무료 학습: mysql 비디오 튜토리얼

목차

  • 1부: 시차 함수 timestampdiff, datediff, timediff
    • 1. 시차 기능: timestampdiff
    • 2 , 시차 함수: datediff
    • 3. 시차 함수: timediff
    • 4. 기타 날짜 함수
    • 기타 날짜 함수
  • 파트 2 날짜, 타임스탬프, 문자열 변환
    • 기타

1부: 시차 함수 timestampdiff, datediff, timediff

1. 시차 함수: timestampdiff

구문: timestampdiff(interval, datetime1,datetime2)
결과: ( time2-time1) , 결과 단위는 간격 매개변수로 제공됩니다.

interval
frac_second 밀리초(낮은 버전은 지원하지 않으므로 초를 사용하고 1000으로 나눕니다.)
초 초
분 분
시 시
일 일
주 주
월 월
분기 분기
연도

참고: MySQL은 MySQL 5.6 이후부터 밀리초 기록 및 계산만 지원합니다. 이전 버전인 경우 데이터베이스에 날짜/시간 유형이 아닌 필드에 밀리초를 저장하기 위한 int 필드를 생성한 후 수행하는 것이 가장 좋습니다. 직접 변환하고 계산하세요. # 모든 형식

SELECT TIMESTAMPDIFF(FRAC_SECOND,'2012-10-01','2013-01-13'); # 暂不支持SELECT TIMESTAMPDIFF(SECOND,'2012-10-01','2013-01-13'); # 8985600SELECT TIMESTAMPDIFF(MINUTE,'2012-10-01','2013-01-13'); # 149760SELECT TIMESTAMPDIFF(HOUR,'2012-10-01','2013-01-13'); # 2496SELECT TIMESTAMPDIFF(DAY,'2012-10-01','2013-01-13'); # 104SELECT TIMESTAMPDIFF(WEEK,'2012-10-01','2013-01-13'); # 14SELECT TIMESTAMPDIFF(MONTH,'2012-10-01','2013-01-13'); # 3SELECT TIMESTAMPDIFF(QUARTER,'2012-10-01','2013-01-13'); # 1SELECT TIMESTAMPDIFF(YEAR,'2012-10-01','2013-01-13'); # 0

2. 시차 기능: datediff

구문: SELECT DATEDIFF (날짜 1, 날짜 2)
결과: 날짜 1 - 날짜 2 사이의 일수 차이

SLECT DATEDIFF('2013-01-13','2012-10-01'); # 104

3. 시간 차이 함수: timediff

구문: timediff(time1, time2)
결과: time1-time2의 차이를 반환합니다.

SELECT TIMEDIFF('2018-05-21 14:51:43','2018-05-19 12:54:43');#49:57:00

참고: 이 메서드의 두 매개 변수는 날짜 형식이어야 합니다

4. 기타 날짜 함수

  • now() 함수는 현재 시간의 연, 월, 일, 시, 분, 초를 반환합니다.
  • curdate() 함수는 연, 월, 일 정보를 반환합니다.
  • curtime() 함수는 현재 시간을 반환합니다. 현재 시간의 시, 분, 초 정보
  • 연, 월, 일, 시, 분, 초의 날짜를 월, 일, 날짜 형식으로 표시합니다. DATE(시간) 기능을 사용할 수 있습니다.
  • 기타 날짜 함수

SELECT NOW(); # 2018-05-21 14:41:00SELECT CURDATE(); # 2018-05-21SELECT CURTIME(); # 14:41:38SELECT DATE(NOW()); # 2018-05-21SELECT SYSDATE(); # 2018-05-21 14:47:11SELECT CURRENT_TIME(); # 14:51:30SELECT CURRENT_TIMESTAMP; # 2018-05-21 14:51:37SELECT CURRENT_TIMESTAMP(); # 2018-05-21 14:51:43
참고: now()는 now()가 실행된다는 점만 제외하면 sysdate()와 유사합니다. 처음에 얻어지고, 함수가 실행될 때 sysdate()를 동적으로 얻을 수 있습니다.

2부 날짜, 타임스탬프 및 문자열을 서로 변환

#时间日期转字符串  相当与Oracle中的to_char函数select date_format(now(), '%Y-%m-%d'); #结果:2017-02-27#时间转时间戳select unix_timestamp(now()); #结果:1488160428#字符串转时间select str_to_date('2017-02-27', '%Y-%m-%d %H'); #结果:2017-02-27 00:00:00select str_to_date('2017-10-16 15:30:28','%Y-%m-%d %H:%i:%s'); #结果 2017-10-16 15:30:28#注意 年是大写‘Y’,小时也必须是大写‘H’    (如果其他为大写,则得到结果为null)#字符串转时间戳select unix_timestamp('2017-02-27'); #结果:1488124800#时间戳转时间select from_unixtime(1488160428); #结果:2017-02-27 09:53:48#时间戳转字符串select from_unixtime(1488160428,'%Y-%m-%d %T'); #结果:2017-02-27 09:53:48

 SELECT DATE_FORMAT(CURDATE(),'%Y-%m-%d %H:%i:%s'); -- 获取当天零点select curdate();                       --获取当前日期select last_day(curdate());                    --获取当月最后一天。select DATE_ADD(curdate(),interval -day(curdate())+1 day);   --获取本月第一天select date_add(curdate()-day(curdate())+1,interval 1 month); -- 获取下个月的第一天select DATEDIFF(date_add(curdate()-day(curdate())+1,interval 1 month ),DATE_ADD(curdate(),interval -day(curdate())+1 day)) from dual; --获取当前月的天数
Others

SELECT DAY('2021-2-17') -- 当前月的第几天(17)SELECT MONTH('2021-2-17') -- 当前为几月(2)
더 많은 관련 무료 학습 권장 사항:

mysql 튜토리얼(동영상)

위 내용은 MySQL에서 일반적으로 사용되는 날짜 관련 함수에 대해 이야기해 보겠습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제