추천 무료 학습: mysql 비디오 튜토리얼
목차
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. 기타 날짜 함수
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!