search
HomeDatabaseMysql TutorialComplete collection of MYSQL date functions

See 7.3.6 Date and Time Types for a description of the range of values ​​each type has and the valid formats for specifying date and time values.

Here is an example of using date functions. The following query selects all records whose date_col value is within the last 30 days:

mysql> SELECT something FROM table 
WHERE TO_DAYS(NOW()) - TO_DAYS(date_col) <= 30;


DAYOFWEEK(date)
Returns the week index of date (1=Sunday, 2=Monday, …7= Saturday). These index values ​​correspond to the ODBC standard.

mysql> select DAYOFWEEK(&#39;1998-02-03&#39;);  
-> 3


WEEKDAY(date)
Returns the week index of date (0=Monday, 1=Tuesday, ...6=Sunday).

mysql> select WEEKDAY(&#39;1997-10-04 22:23:00&#39;);  
-> 5  
mysql> select WEEKDAY(&#39;1997-11-05&#39;);  
-> 2


DAYOFMONTH(date)
Returns the day of the month of date, in the range of 1 to 31.

mysql> select DAYOFMONTH(&#39;1998-02-03&#39;);  
-> 3


DAYOFYEAR(date)
Returns the day of the year in the range of 1 to 366.

mysql> select DAYOFYEAR(&#39;1998-02-03&#39;);  
-> 34


MONTH(date)
Returns the month of date, ranging from 1 to 12.

mysql> select MONTH(&#39;1998-02-03&#39;);  
-> 2


DAYNAME(date)
Returns the day of the week name of date.

mysql> select DAYNAME("1998-02-05");  
-> &#39;Thursday&#39;


MONTHNAME(date)
Returns the month name of date.

mysql> select MONTHNAME("1998-02-05");  
-> &#39;February&#39;


QUARTER(date)
Returns the quarter of the year in date, ranging from 1 to 4.

mysql> select QUARTER(&#39;98-04-01&#39;);  
-> 2


WEEK(date)

WEEK(date,first)
For places where Sunday is the first day of the week, there is a single parameter that returns the week number of date, ranging from 0 to 52. 2 parameter form WEEK() allows you to specify whether the week starts on Sunday or Monday. If the second argument is 0, the week starts on Sunday, if the second argument is 1,
starts on Monday.

mysql> select WEEK(&#39;1998-02-20&#39;);  
-> 7  
mysql> select WEEK(&#39;1998-02-20&#39;,0);  
-> 7  
mysql> select WEEK(&#39;1998-02-20&#39;,1);  
-> 8

YEAR(date)
Returns the year of date, ranging from 1000 to 9999.

mysql> select YEAR(&#39;98-02-03&#39;);  
-> 1998


HOUR(time)
Returns the hour of time, ranging from 0 to 23.

mysql> select HOUR(&#39;10:05:03&#39;);  
-> 10

MINUTE(time)

Returns the minute of time, ranging from 0 to 59.

mysql> select MINUTE(&#39;98-02-03 10:05:03&#39;);  
-> 5

SECOND(time)
Returns the number of seconds of time, ranging from 0 to 59.

mysql> select SECOND(&#39;10:05:03&#39;);  
-> 3

PERIOD_ADD(P,N)
Add N months to phase P (in format YYMM or YYYYMM). Returns the value in the format YYYYMM. Note that the phase parameter P is not a date value.

mysql> select PERIOD_ADD(9801,2);  
-> 199803

PERIOD_DIFF(P1,P2)
Returns the number of months between periods P1 and P2, P1 and P2 should be in the format YYMM or YYYYMM. Note that the period parameters P1 and P2 are not date values.

mysql> select PERIOD_DIFF(9802,199703);  
-> 11
 
DATE_ADD(date,INTERVAL expr type)  
   
DATE_SUB(date,INTERVAL expr type)  
   
ADDDATE(date,INTERVAL expr type)  
   
SUBDATE(date,INTERVAL expr type)

These functions perform date operations. As of MySQL 3.22, they are new. ADDDATE() and SUBDATE() are synonyms of DATE_ADD() and DATE_SUB().

In MySQL 3.23, you can use + and - instead of DATE_ADD() and DATE_SUB(). (see example) date is a
DATETIME or DATE value that specifies the start date, expr is an expression that specifies the interval value to be added to or subtracted from the start date, expr is a string; it can start with
a "- ” starts to indicate a negative interval. type is a keyword that specifies how the expression should be interpreted. The EXTRACT(type FROM date) function returns the "type" interval from the date
. The following table shows how the type and expr parameters are related: type value meaning expected expr format
SECOND seconds SECONDS
MINUTE minutes MINUTES
HOUR time HOURS
DAY days DAYS
MONTH months MONTHS
YEAR years YEARS
MINUTE_SECOND minutes and seconds "MINUTES" :SECONDS"
HOUR_MINUTE hours and minutes "HOURS:MINUTES"
DAY_HOUR days and hours "DAYS HOURS"
YEAR_MONTH years and months "YEARS-MONTHS"
HOUR_SECOND hours, minutes, "HOURS:MINUTES:SECONDS"
DAY_MINUTE days, hours , minutes "DAYS HOURS:MINUTES"
DAY_SECOND days, hours, minutes, seconds "DAYS HOURS:MINUTES:SECONDS"

MySQL allows any punctuation separator in expr format. Indicates that recommended separators are displayed. If the date argument is a DATE value and your calculation contains only YEAR, MONTH, and DAY components (i.e., no time component), the result is a DATE value. Otherwise the result is a DATETIME value.


mysql> SELECT "1997-12-31 23:59:59" + INTERVAL 1 SECOND;  
-> 1998-01-01 00:00:00  
mysql> SELECT INTERVAL 1 DAY + "1997-12-31";  
-> 1998-01-01  
mysql> SELECT "1998-01-01" - INTERVAL 1 SECOND;  
-> 1997-12-31 23:59:59  
mysql> SELECT DATE_ADD("1997-12-31 23:59:59",  
INTERVAL 1 SECOND);  
-> 1998-01-01 00:00:00  
mysql> SELECT DATE_ADD("1997-12-31 23:59:59",  
INTERVAL 1 DAY);  
-> 1998-01-01 23:59:59  
mysql> SELECT DATE_ADD("1997-12-31 23:59:59",  
INTERVAL "1:1" MINUTE_SECOND);  
-> 1998-01-01 00:01:00  
mysql> SELECT DATE_SUB("1998-01-01 00:00:00",  
INTERVAL "1 1:1:1" DAY_SECOND);  
-> 1997-12-30 22:58:59  
mysql> SELECT DATE_ADD("1998-01-01 00:00:00",  
INTERVAL "-1 10" DAY_HOUR);  
-> 1997-12-30 14:00:00  
mysql> SELECT DATE_SUB("1998-01-02", INTERVAL 31 DAY);  
-> 1997-12-02  
mysql> SELECT EXTRACT(YEAR FROM "1999-07-02");  
-> 1999  
mysql> SELECT EXTRACT(YEAR_MONTH FROM "1999-07-02 01:02:03");  
-> 199907  
mysql> SELECT EXTRACT(DAY_MINUTE FROM "1999-07-02 01:02:03");  
-> 20102

If you specify an interval value that is too short (excluding the interval expected by the type keyword), MySQL assumes that you omitted the leftmost part of the interval value. For example,

If you specify a type of DAY_SECOND, the value expr is expected to have day, hour, minute and second components. If you specify a value like "1:10",
MySQL assumes that the day and hour parts are missing and the value represents minutes and seconds. In other words, "1:10" DAY_SECOND is interpreted in a way that it is equivalent to "1:10" MINUTE_SECOND
, which is ambiguous to the way MySQL interprets the TIME value to represent an elapsed time rather than as a time of day. If you use a really incorrect date,
the result is NULL. If you increment MONTH, YEAR_MONTH, or YEAR and the resulting date is greater than the maximum number of days in the new month, the days are adjusted to the maximum number of days in the new month.


mysql> select DATE_ADD(&#39;1998-01-30&#39;, Interval 1 month);  
-> 1998-02-28

 
注意,从前面的例子中词INTERVAL和type关键词不是区分大小写的。  
TO_DAYS(date)  
给出一个日期date,返回一个天数(从0年的天数)。  

mysql> select TO_DAYS(950501);  
-> 728779
mysql> select TO_DAYS(&#39;1997-10-07&#39;);  
-> 729669

 
TO_DAYS()不打算用于使用格列高里历(1582)出现前的值。  
 
FROM_DAYS(N)  
给出一个天数N,返回一个DATE值。  

mysql> select FROM_DAYS(729669);  
-> &#39;1997-10-07&#39;

 
TO_DAYS()不打算用于使用格列高里历(1582)出现前的值。  
 
DATE_FORMAT(date,format)  
根据format字符串格式化date值。下列修饰符可以被用在format字符串中: %M 月名字(January……December)  
%W 星期名字(Sunday……Saturday)  
%D 有英语前缀的月份的日期(1st, 2nd, 3rd, 等等。)  
%Y 年, 数字, 4 位  
%y 年, 数字, 2 位  
%a 缩写的星期名字(Sun……Sat)  
%d 月份中的天数, 数字(00……31)  
%e 月份中的天数, 数字(0……31)  
%m 月, 数字(01……12)  
%c 月, 数字(1……12)  
%b 缩写的月份名字(Jan……Dec)  
%j 一年中的天数(001……366)  
%H 小时(00……23)  
%k 小时(0……23)  
%h 小时(01……12)  
%I 小时(01……12)  
%l 小时(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=Sunday ……6=Saturday )  
%U 星期(0……52), 这里星期天是星期的第一天  
%u 星期(0……52), 这里星期一是星期的第一天  
%% 一个文字“%”。  
 
所有的其他字符不做解释被复制到结果中。  
 

mysql> select DATE_FORMAT(&#39;1997-10-04 22:23:00&#39;, &#39;%W %M %Y&#39;);  
-> &#39;Saturday October 1997&#39; 
mysql> select DATE_FORMAT(&#39;1997-10-04 22:23:00&#39;, &#39;%H:%i:%s&#39;);  
-> &#39;22:23:00&#39; 
mysql> select DATE_FORMAT(&#39;1997-10-04 22:23:00&#39;,  
&#39;%D %y %a %d %m %b %j&#39;);  
-> &#39;4th 97 Sat 04 10 Oct 277&#39; 
mysql> select DATE_FORMAT(&#39;1997-10-04 22:23:00&#39;,  
&#39;%H %k %I %r %T %S %w&#39;);  
-> &#39;22 22 10 10:23:00 PM 22:23:00 00 6&#39;

MySQL3.23中,在格式修饰符字符前需要%。在MySQL更早的版本中,%是可选的。  
 
TIME_FORMAT(time,format)  
这象上面的DATE_FORMAT()函数一样使用,但是format字符串只能包含处理小时、分钟和秒的那些格式修饰符。
其他修饰符产生一个NULL值或0。  
CURDATE()  
   
CURRENT_DATE
以'YYYY-MM-DD'或YYYYMMDD格式返回今天日期值,取决于函数是在一个字符串还是数字上下文被使用。  

mysql> select CURDATE();  
-> &#39;1997-12-15&#39; 
mysql> select CURDATE() + 0;  
-> 19971215

 
CURTIME()  
   
CURRENT_TIME
以'HH:MM:SS'或HHMMSS格式返回当前时间值,取决于函数是在一个字符串还是在数字的上下文被使用。  

mysql> select CURTIME();  
-> &#39;23:50:26&#39; 
mysql> select CURTIME() + 0;  
-> 235026

 
NOW()  
   
SYSDATE()  
   
CURRENT_TIMESTAMP
以'YYYY-MM-DD HH:MM:SS'或YYYYMMDDHHMMSS格式返回当前的日期和时间,取决于函数是在一个字符串还是在数字的
上下文被使用。  

mysql> select NOW();  
-> &#39;1997-12-15 23:50:26&#39; 
mysql> select NOW() + 0;  
-> 19971215235026

 
UNIX_TIMESTAMP()  
   
UNIX_TIMESTAMP(date)  
如果没有参数调用,返回一个Unix时间戳记(从'1970-01-01 00:00:00'GMT开始的秒数)。如果UNIX_TIMESTAMP()用一
个date参数被调用,它返回从'1970-01-01 00:00:00' GMT开始的秒数值。date可以是一个DATE字符串、一个DATETIME
字符串、一个TIMESTAMP或以YYMMDD或YYYYMMDD格式的本地时间的一个数字。  

mysql> select UNIX_TIMESTAMP();  
-> 882226357  
mysql> select UNIX_TIMESTAMP(&#39;1997-10-04 22:23:00&#39;);  
-> 875996580

 
当UNIX_TIMESTAMP被用于一个TIMESTAMP列,函数将直接接受值,没有隐含的“string-to-unix-timestamp”变换。  
 
FROM_UNIXTIME(unix_timestamp)  
以'YYYY-MM-DD HH:MM:SS'或YYYYMMDDHHMMSS格式返回unix_timestamp参数所表示的值,取决于函数是在一个字符串
还是或数字上下文中被使用。  

mysql> select FROM_UNIXTIME(875996580);  
-> &#39;1997-10-04 22:23:00&#39; 
mysql> select FROM_UNIXTIME(875996580) + 0;  
-> 19971004222300

 
FROM_UNIXTIME(unix_timestamp,format)  
返回表示 Unix 时间标记的一个字符串,根据format字符串格式化。format可以包含与DATE_FORMAT()函数列出的条
目同样的修饰符。  

mysql> select FROM_UNIXTIME(UNIX_TIMESTAMP(),  
&#39;%Y %D %M %h:%i:%s %x&#39;);  
-> &#39;1997 23rd December 03:43:30 x&#39;

 
SEC_TO_TIME(seconds)  
返回seconds参数,变换成小时、分钟和秒,值以'HH:MM:SS'或HHMMSS格式化,取决于函数是在一个字符串还是在数字
上下文中被使用。  

mysql> select SEC_TO_TIME(2378);  
-> &#39;00:39:38&#39; 
mysql> select SEC_TO_TIME(2378) + 0;  
-> 3938

 
TIME_TO_SEC(time)  
返回time参数,转换成秒。  

mysql> select TIME_TO_SEC(&#39;22:23:00&#39;);  
-> 80580  
mysql> select TIME_TO_SEC(&#39;00:39:38&#39;);  
-> 2378


Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Reduce the use of MySQL memory in DockerReduce the use of MySQL memory in DockerMar 04, 2025 pm 03:52 PM

This article explores optimizing MySQL memory usage in Docker. It discusses monitoring techniques (Docker stats, Performance Schema, external tools) and configuration strategies. These include Docker memory limits, swapping, and cgroups, alongside

How to solve the problem of mysql cannot open shared libraryHow to solve the problem of mysql cannot open shared libraryMar 04, 2025 pm 04:01 PM

This article addresses MySQL's "unable to open shared library" error. The issue stems from MySQL's inability to locate necessary shared libraries (.so/.dll files). Solutions involve verifying library installation via the system's package m

How do you alter a table in MySQL using the ALTER TABLE statement?How do you alter a table in MySQL using the ALTER TABLE statement?Mar 19, 2025 pm 03:51 PM

The article discusses using MySQL's ALTER TABLE statement to modify tables, including adding/dropping columns, renaming tables/columns, and changing column data types.

Run MySQl in Linux (with/without podman container with phpmyadmin)Run MySQl in Linux (with/without podman container with phpmyadmin)Mar 04, 2025 pm 03:54 PM

This article compares installing MySQL on Linux directly versus using Podman containers, with/without phpMyAdmin. It details installation steps for each method, emphasizing Podman's advantages in isolation, portability, and reproducibility, but also

What is SQLite? Comprehensive overviewWhat is SQLite? Comprehensive overviewMar 04, 2025 pm 03:55 PM

This article provides a comprehensive overview of SQLite, a self-contained, serverless relational database. It details SQLite's advantages (simplicity, portability, ease of use) and disadvantages (concurrency limitations, scalability challenges). C

How do I configure SSL/TLS encryption for MySQL connections?How do I configure SSL/TLS encryption for MySQL connections?Mar 18, 2025 pm 12:01 PM

Article discusses configuring SSL/TLS encryption for MySQL, including certificate generation and verification. Main issue is using self-signed certificates' security implications.[Character count: 159]

Running multiple MySQL versions on MacOS: A step-by-step guideRunning multiple MySQL versions on MacOS: A step-by-step guideMar 04, 2025 pm 03:49 PM

This guide demonstrates installing and managing multiple MySQL versions on macOS using Homebrew. It emphasizes using Homebrew to isolate installations, preventing conflicts. The article details installation, starting/stopping services, and best pra

What are some popular MySQL GUI tools (e.g., MySQL Workbench, phpMyAdmin)?What are some popular MySQL GUI tools (e.g., MySQL Workbench, phpMyAdmin)?Mar 21, 2025 pm 06:28 PM

Article discusses popular MySQL GUI tools like MySQL Workbench and phpMyAdmin, comparing their features and suitability for beginners and advanced users.[159 characters]

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),