mysql常用日期與計算函數實例講解

mysql數據庫中的日期比較與計算是經常用到的,例如比較兩個日期大小,計算兩個日期相差多少天,本文主要和大家分享mysql常用日期與計算函數實例,希望能幫助到大家。

unix_timestamp()

unix_timestamp 函數可以接受一個參數,也可以不使用參數。

它的返回值是一個無符號的整數。不使用參數,它返回自1970年1月1日0時0分0秒到現在所經過的秒數,

如果 使用參數,參數的類型為時間類型或者時間類型的字符串表示,則是從1970-01-01 00:00:00到指定時間所經歷的秒數。

有了這個函數,就可以很自然地把時間比較轉換為一個無符號整數的比較。

例如,判斷一個時間是否在一個區間內

unix_timestamp(?time?)?between?unix_timestamp(?'start?')?and?unix_timestamp(?'end'?)

這里是一個使用日期函數的例子。

下面的查詢選擇了所有記錄,其date_col的值是在最后30天以內:

mysql&gt;?SELECT?something?FROM?table?WHERE?TO_DAYS(NOW())?-?TO_DAYS(date_col)?<p><strong>DAYOFWEEK(date)</strong></p><p>返回日期date的星期索引(1=星期天,2=星期一, ……7=星期六)。這些索引值對應于ODBC標準。</p><p class="jb51code"><br></p><pre class="brush:bash;">mysql&gt;?select?DAYOFWEEK('1998-02-03');  -&gt;?3

WEEKDAY(date)

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

mysql&gt;?select?WEEKDAY('1997-10-04?22:23:00');  -&gt;?5  mysql&gt;?select?WEEKDAY('1997-11-05');  -&gt;?2

DAYOFMONTH(date)

返回date的月份中日期,在1到31范圍內。

mysql&gt;?select?DAYOFMONTH('1998-02-03');  -&gt;?3

DAYOFYEAR(date)

返回date在一年中的日數, 在1到366范圍內。

mysql&gt;?select?DAYOFYEAR('1998-02-03');  -&gt;?34

MONTH(date)

返回date的月份,范圍1到12。

mysql&gt;?select?MONTH('1998-02-03');  -&gt;?2

DAYNAME(date)

返回date的星期名字。

mysql&gt;?select?DAYNAME("1998-02-05");  -&gt;?'Thursday'

MONTHNAME(date)

返回date的月份名字。

mysql&gt;?select?MONTHNAME("1998-02-05");  -&gt;?'February'

QUARTER(date)

返回date一年中的季度,范圍1到4。

mysql&gt;?select?QUARTER('98-04-01');  -&gt;?2

WEEK(date)

WEEK(date,first)

對于星期天是一周的第一天的地方,有一個單個參數,返回date的周數,范圍在0到52。2個參數形式WEEK()允許你指定星期是否開始于星期天或星期一。如果第二個參數是0,星期從星期天開始,如果第二個參數是1,從星期一開始。

mysql&gt;?select?WEEK('1998-02-20');  -&gt;?7  mysql&gt;?select?WEEK('1998-02-20',0);  -&gt;?7  mysql&gt;?select?WEEK('1998-02-20',1);  -&gt;?8

YEAR(date)

返回date的年份,范圍在1000到9999。

mysql&gt;?select?YEAR('98-02-03');  -&gt;?1998

HOUR(time)

返回time的小時,范圍是0到23。

mysql&gt;?select?HOUR('10:05:03');  -&gt;?10

MINUTE(time)

返回time的分鐘,范圍是0到59。

mysql&gt;?select?MINUTE('98-02-03?10:05:03');  -&gt;?5

SECOND(time)

回來time的秒數,范圍是0到59。

mysql&gt;?select?SECOND('10:05:03');  -&gt;?3

PERIOD_ADD(P,N)

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

mysql&gt;?select?PERIOD_ADD(9801,2);  -&gt;?199803

PERIOD_DIFF(P1,P2)

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

mysql&gt;?select?PERIOD_DIFF(9802,199703);  -&gt;?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 小時, 分鐘, “HOURS:MINUTES:SECONDS”
DAY_MINUTE 天, 小時, 分鐘 “DAYS HOURS:MINUTES”
DAY_SECOND 天, 小時, 分鐘, 秒 “DAYS HOURS:MINUTES:SECONDS”

MySQL在expr格式中允許任何標點分隔符。表示顯示的是建議的分隔符。如果date參數是一個DATE值并且你的計算僅僅包含YEAR、MONTH和DAY部分(即,沒有時間部分),結果是一個DATE值。否則結果是一個DATETIME值.

mysql&gt;?SELECT?"1997-12-31?23:59:59"?+?INTERVAL?1?SECOND;  -&gt;?1998-01-01?00:00:00  mysql&gt;?SELECT?INTERVAL?1?DAY?+?"1997-12-31";  -&gt;?1998-01-01  mysql&gt;?SELECT?"1998-01-01"?-?INTERVAL?1?SECOND;  -&gt;?1997-12-31?23:59:59  mysql&gt;?SELECT?DATE_ADD("1997-12-31?23:59:59",  INTERVAL?1?SECOND);  -&gt;?1998-01-01?00:00:00  mysql&gt;?SELECT?DATE_ADD("1997-12-31?23:59:59",  INTERVAL?1?DAY);  -&gt;?1998-01-01?23:59:59  mysql&gt;?SELECT?DATE_ADD("1997-12-31?23:59:59",  INTERVAL?"1:1"?MINUTE_SECOND);  -&gt;?1998-01-01?00:01:00  mysql&gt;?SELECT?DATE_SUB("1998-01-01?00:00:00",  INTERVAL?"1?1:1:1"?DAY_SECOND);  -&gt;?1997-12-30?22:58:59  mysql&gt;?SELECT?DATE_ADD("1998-01-01?00:00:00",  INTERVAL?"-1?10"?DAY_HOUR);  -&gt;?1997-12-30?14:00:00  mysql&gt;?SELECT?DATE_SUB("1998-01-02",?INTERVAL?31?DAY);  -&gt;?1997-12-02  mysql&gt;?SELECT?EXTRACT(YEAR?FROM?"1999-07-02");  -&gt;?1999  mysql&gt;?SELECT?EXTRACT(YEAR_MONTH?FROM?"1999-07-02?01:02:03");  -&gt;?199907  mysql&gt;?SELECT?EXTRACT(DAY_MINUTE?FROM?"1999-07-02?01:02:03");  -&gt;?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&gt;?select?DATE_ADD('1998-01-30',?Interval?1?month);  -&gt;?1998-02-28

注意,從前面的例子中詞INTERVAL和type關鍵詞不是區分大小寫的。

TO_DAYS(date)

給出一個日期date,返回一個天數(從0年的天數)。

mysql&gt;?select?TO_DAYS(950501);  -&gt;?728779  mysql&gt;?select?TO_DAYS('1997-10-07');  -&gt;?729669

FROM_DAYS(N)

給出一個天數N,返回一個DATE值。

mysql&gt;?select?FROM_DAYS(729669);  -&gt;?'1997-10-07'

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

MySQL3.23中,在格式修飾符字符前需要%。在MySQL更早的版本中,%是可選的。

TIME_FORMAT(time,format)

這象上面的DATE_FORMAT()函數一樣使用,但是format字符串只能包含處理小時、分鐘和秒的那些格式修飾符。其他修飾符產生一個NULL值或0。

CURDATE()

CURRENT_DATE以’YYYY-MM-DD’或YYYYMMDD格式返回今天日期值,取決于函數是在一個字符串還是數字上下文被使用。

mysql&gt;?select?CURDATE();  -&gt;?'1997-12-15'  mysql&gt;?select?CURDATE()?+?0;  -&gt;?19971215

CURTIME()

CURRENT_TIME

以’HH:MM:SS’或HHMMSS格式返回當前時間值,取決于函數是在一個字符串還是在數字的上下文被使用。

mysql&gt;?select?CURTIME();  -&gt;?'23:50:26'  mysql&gt;?select?CURTIME()?+?0;  -&gt;?235026

NOW()

SYSDATE()

CURRENT_TIMESTAMP 以’YYYY-MM-DD HH:MM:SS’或YYYYMMDDHHMMSS格式返回當前的日期和時間,取決于函數是在一個字符串還是在數字的上下文被使用。

mysql&gt;?select?NOW();  -&gt;?'1997-12-15?23:50:26'  mysql&gt;?select?NOW()?+?0;  -&gt;?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&gt;?select?UNIX_TIMESTAMP();  -&gt;?882226357  mysql&gt;?select?UNIX_TIMESTAMP('1997-10-04?22:23:00');  -&gt;?875996580

當UNIX_TIMESTAMP被用于一個TIMESTAMP列,函數將直接接受值,沒有隱含的“string-to-unix-timestamp”變換。

FROM_UNIXTIME(unix_timestamp)

以’YYYY-MM-DD HH:MM:SS’或YYYYMMDDHHMMSS格式返回unix_timestamp參數所表示的值,取決于函數是在一個字符串
還是或數字上下文中被使用。

mysql&gt;?select?FROM_UNIXTIME(875996580);  -&gt;?'1997-10-04?22:23:00'  mysql&gt;?select?FROM_UNIXTIME(875996580)?+?0;  -&gt;?19971004222300

FROM_UNIXTIME(unix_timestamp,format)

返回表示 Unix 時間標記的一個字符串,根據format字符串格式化。format可以包含與DATE_FORMAT()函數列出的條目同樣的修飾符。

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

SEC_TO_TIME(seconds)

返回seconds參數,變換成小時、分鐘和秒,值以’HH:MM:SS’或HHMMSS格式化,取決于函數是在一個字符串還是在數字 上下文中被使用。

mysql&gt;?select?SEC_TO_TIME(2378);  -&gt;?'00:39:38'  mysql&gt;?select?SEC_TO_TIME(2378)?+?0;  -&gt;?3938

TIME_TO_SEC(time)

返回time參數,轉換成秒。

mysql&gt;?select?TIME_TO_SEC('22:23:00');  -&gt;?80580  mysql&gt;?select?TIME_TO_SEC('00:39:38');  -&gt;?2378

Mysql的日期函數很多,用作日期比較的函數有時并不一定是一個函數有可能是多個函數組合在一起使用,所以大家要發揮自己的想像力

相關推薦:

mysql常用日期時間/數值函數_MySQL

mysql常用日期時間/數值函數_MySQL

mysql常用日期時間/數值函數_MySQL

? 版權聲明
THE END
喜歡就支持一下吧
點贊13 分享