搜尋
首頁資料庫mysql教程MYSQL 日期函數大全

對於每個類型擁有的值範圍以及並且指定日期何時間值的有效格式的描述請參閱7.3.6 日期和時間類型。  
 
這裡是一個使用日期函數的範例。下面的查詢選擇了所有記錄,其date_col的值是在最後30天以內:  
 

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

 
DAYOFWEEK(date)  
返回日期date的星期索引(1=星期日,2=星期一, 7=星期六)。這些索引值對應於ODBC標準。  

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

 
WEEKDAY(date)  
返回date的星期索引(0=星期一,1=星期二, …6= 星期日)。  

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

 
DAYOFMONTH(date)  
返回date的月份中日期,在1到31範圍內。  

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

 
DAYOFYEAR(date)  
返回date在一年中的日數, 在1到366範圍內。  

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

 
MONTH(date)  
回到date的月份,範圍1到12。  

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

 
DAYNAME(date)  
返回date的星期名字。  

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

 
MONTHNAME(date)  
回傳date的月份名字。  

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

 
QUARTER(date)  
返回date一年中的季度,範圍1到4。

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

 
WEEK(date)  
   
WEEK(date,first)  
對於星期日是一周的第一天的地方,有一個單一參數,返回date的周數,範圍在052。 WEEK()允許
你指定星期是否開始於星期日或星期一。如果第二個參數是0,則星期從星期日開始,如果第二個參數是1,
從星期一開始。  

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)  
回到date的年份,範圍在1000到9999。  

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

 
 
HOUR(time)  
返回time的小時,範圍是0到23。  

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

MINUTE(time)  
返回time的分鐘,範圍是0到59。  

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

 
SECOND(time)  
回來time的秒數,範圍是0到59。  

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

 
PERIOD_ADD(P,N)  
增加N個月到階段P(以格式YYMM或YYYYMM)。以格式YYYYMM傳回值。注意階段參數P不是日期值。  

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

 
PERIOD_DIFF(P1,P2)  
返回在期間P1和P2之間月數,P1和P2應該以格式YYMM或YYYYMM。注意,時期參數P1和P2不是日期值。  

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)

這些功能執行日期運算。對於MySQL 3.22,他們是新的。 ADDDATE()和SUBDATE()是DATE_ADD()和DATE_SUB()的同義詞。
在MySQL 3.23中,你可以使用+和-而不是DATE_ADD()和DATE_SUB()。 (見例子)date是指定開始日期的
DATETIME或DATE值,expr是指定加到開始日期或從開始日期減去的間隔值一個表達式,expr是一個字串;它可以以
一個「- 」開始表示負間隔。 type是一個關鍵字,指明表達式應該如何解釋。 EXTRACT(type FROM date)函數從日期
中傳回「type」間隔。下表顯示了type和expr參數怎樣被關聯: type值含義期望的expr格式 
SECOND 秒SECONDS  
MINUTE 分鐘MINUTES  
HOUR 時間HOURS  
DAY 天DAYS  
MONTH 月MONTHS  
YEAR 年YEARS  
MINUTE_SECOND 分鐘和秒"MINUTES :SECONDS"
HOUR_MINUTE 小時和分鐘"HOURS:MINUTES"
DAY_HOUR 天和小時"DAYS HOURS"
YEAR_MONTH 年和月"YEARS-MONTHS"
HOUR_SECOND 小時,COND 小時,COND.D. , 分鐘"DAYS HOURS:MINUTES"
DAY_SECOND 天, 小時, 分鐘, 秒"DAYS HOURS:MINUTES:SECONDS"
 
MySQL在expr格式中允許任何標點分隔符。表示顯示的是建議的分隔符號。如果date參數是一個DATE值且你的計算只是
包含YEAR、MONTH和DAY部分(即,沒有時間部分),結果就是一個DATE值。否則結果就是一個DATETIME值。  
 

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

 

如果你指定太短的間隔值(不包括type關鍵字期望的間隔部分),MySQL假設你省掉了間隔值的最左面部分。例如,
如果你指定一個type是DAY_SECOND,值expr被希望有天、小時、分鐘和秒部分。如果你像"1:10"這樣指定值,
MySQL假設日子和小時部分是丟失的並且值代表分鐘和秒。換句話說,"1:10" DAY_SECOND以它等價於"1:10" MINUTE_SECOND
的方式解釋,這對那MySQL解釋TIME值表示經過的時間而非作為一天的時間的方式有二義性。如果你使用確實不正確的日期,
結果是NULL。如果你增加MONTH、YEAR_MONTH或YEAR且結果日期大於新月份的最大值天數,日子在新月用最大的天調整。  
 

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


陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
MySQL的許可與其他數據庫系統相比如何?MySQL的許可與其他數據庫系統相比如何?Apr 25, 2025 am 12:26 AM

MySQL使用的是GPL許可證。 1)GPL許可證允許自由使用、修改和分發MySQL,但修改後的分發需遵循GPL。 2)商業許可證可避免公開修改,適合需要保密的商業應用。

您什麼時候選擇InnoDB而不是Myisam,反之亦然?您什麼時候選擇InnoDB而不是Myisam,反之亦然?Apr 25, 2025 am 12:22 AM

選擇InnoDB而不是MyISAM的情況包括:1)需要事務支持,2)高並發環境,3)需要高數據一致性;反之,選擇MyISAM的情況包括:1)主要是讀操作,2)不需要事務支持。 InnoDB適合需要高數據一致性和事務處理的應用,如電商平台,而MyISAM適合讀密集型且無需事務的應用,如博客系統。

在MySQL中解釋外鍵的目的。在MySQL中解釋外鍵的目的。Apr 25, 2025 am 12:17 AM

在MySQL中,外鍵的作用是建立表與表之間的關係,確保數據的一致性和完整性。外鍵通過引用完整性檢查和級聯操作維護數據的有效性,使用時需注意性能優化和避免常見錯誤。

MySQL中有哪些不同類型的索引?MySQL中有哪些不同類型的索引?Apr 25, 2025 am 12:12 AM

MySQL中有四種主要的索引類型:B-Tree索引、哈希索引、全文索引和空間索引。 1.B-Tree索引適用於範圍查詢、排序和分組,適合在employees表的name列上創建。 2.哈希索引適用於等值查詢,適合在MEMORY存儲引擎的hash_table表的id列上創建。 3.全文索引用於文本搜索,適合在articles表的content列上創建。 4.空間索引用於地理空間查詢,適合在locations表的geom列上創建。

您如何在MySQL中創建索引?您如何在MySQL中創建索引?Apr 25, 2025 am 12:06 AM

toCreateAnIndexinMysql,usethecReateIndexStatement.1)forasingLecolumn,使用“ createIndexIdx_lastNameEnemployees(lastName); 2)foracompositeIndex,使用“ createIndexIndexIndexIndexIndexDx_nameOmplayees(lastName,firstName,firstName);” 3)forauniqe instex,creationexexexexex,

MySQL與Sqlite有何不同?MySQL與Sqlite有何不同?Apr 24, 2025 am 12:12 AM

MySQL和SQLite的主要區別在於設計理念和使用場景:1.MySQL適用於大型應用和企業級解決方案,支持高性能和高並發;2.SQLite適合移動應用和桌面軟件,輕量級且易於嵌入。

MySQL中的索引是什麼?它們如何提高性能?MySQL中的索引是什麼?它們如何提高性能?Apr 24, 2025 am 12:09 AM

MySQL中的索引是數據庫表中一列或多列的有序結構,用於加速數據檢索。 1)索引通過減少掃描數據量提升查詢速度。 2)B-Tree索引利用平衡樹結構,適合範圍查詢和排序。 3)創建索引使用CREATEINDEX語句,如CREATEINDEXidx_customer_idONorders(customer_id)。 4)複合索引可優化多列查詢,如CREATEINDEXidx_customer_orderONorders(customer_id,order_date)。 5)使用EXPLAIN分析查詢計劃,避

說明如何使用MySQL中的交易來確保數據一致性。說明如何使用MySQL中的交易來確保數據一致性。Apr 24, 2025 am 12:09 AM

在MySQL中使用事務可以確保數據一致性。 1)通過STARTTRANSACTION開始事務,執行SQL操作後用COMMIT提交或ROLLBACK回滾。 2)使用SAVEPOINT可以設置保存點,允許部分回滾。 3)性能優化建議包括縮短事務時間、避免大規模查詢和合理使用隔離級別。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具