萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> mysql教程 >> mysql時間日期用法總結

mysql時間日期用法總結

本文章詳細的介紹mysql中時間日期的各種用法以及時間日期的各種常用方法,有需要了解的朋友可以簡單的參考一下下哈。

1獲得當前日期+時間(date + time)1.1    函數:now()

 相關函數:current_timestamp(),localtime(),localtimestamp()

2. 獲得當前日期(date)

 函數:curdate()

 相關函數:current_date(),current_date

 3. 獲得當前時間(time)

函數:curtime()

 相關函數:current_time(),current_time


 
4. MySQL dayof…

函數:dayofweek(), dayofmonth(), dayofyear()分別返回日期參數,在一周、一月、一年中的位置。

舉例說明

set @dt = '2008-08-08';

select dayofweek(@dt); -- 6

select dayofmonth(@dt); -- 8

select dayofyear(@dt); -- 221

日期‘2008-08-08′ 是一周中的第6 天(1 = Sunday, 2 = Monday, …, 7 = Saturday)

一月中的第8 天;一年中的第221 天

MySQL 獲得當前日期時間 函數
1.1 獲得當前日期+時間(date + time)函數:now()

mysql> select now();

+---------------------+
| now()               |
+---------------------+
| 2008-08-08 22:20:46 |
+---------------------+除了 now() 函數能獲得當前的日期時間外,MySQL 中還有下面的函數:

current_timestamp()
,current_timestamp
,localtime()
,localtime
,localtimestamp    -- (v4.0.6)
,localtimestamp()  -- (v4.0.6)這些日期時間函數,都等同於 now()。鑒於 now() 函數簡短易記,建議總是使用 now() 來替代上面列出的函數。

1.2 獲得當前日期+時間(date + time)函數:sysdate()

sysdate() 日期時間函數跟 now() 類似,不同之處在於:now() 在執行開始時值就得到了, sysdate() 在函數執行時動態得到值。看下面的例子就明白了:

mysql> select now(), sleep(3), now();

+---------------------+----------+---------------------+
| now()               | sleep(3) | now()               |
+---------------------+----------+---------------------+
| 2008-08-08 22:28:21 |        0 | 2008-08-08 22:28:21 |
+---------------------+----------+---------------------+mysql> select sysdate(), sleep(3), sysdate();

+---------------------+----------+---------------------+
| sysdate()           | sleep(3) | sysdate()           |
+---------------------+----------+---------------------+
| 2008-08-08 22:28:41 |        0 | 2008-08-08 22:28:44 |
+---------------------+----------+---------------------+可以看到,雖然中途 sleep 3 秒,但 now() 函數兩次的時間值是相同的; sysdate() 函數兩次得到的時間值相差 3 秒。MySQL Manual 中是這樣描述 sysdate() 的:Return the time at which the function executes。

sysdate() 日期時間函數,一般情況下很少用到。

2. 獲得當前日期(date)函數:curdate()

mysql> select curdate();

+------------+
| curdate()  |
+------------+
| 2008-08-08 |
+------------+其中,下面的兩個日期函數等同於 curdate():

current_date()
,current_date3. 獲得當前時間(time)函數:curtime()

mysql> select curtime();

+-----------+
| curtime() |
+-----------+
| 22:41:30  |
+-----------+其中,下面的兩個時間函數等同於 curtime():

current_time()
,current_time4. 獲得當前 UTC 日期時間函數:utc_date(), utc_time(), utc_timestamp()

mysql> select utc_timestamp(), utc_date(), utc_time(), now()

+---------------------+------------+------------+---------------------+
| utc_timestamp()     | utc_date() | utc_time() | now()               |
+---------------------+------------+------------+---------------------+
| 2008-08-08 14:47:11 | 2008-08-08 | 14:47:11   | 2008-08-08 22:47:11 |
+---------------------+------------+------------+---------------------+因為我國位於東八時區,所以本地時間 = UTC 時間 + 8 小時。UTC 時間在業務涉及多個國家和地區的時候,非常有用。

網上搜集轉載,方便查閱(最好的當然是www.mysql.cn的函數查詢)

這裡是一個使用日期函數的例子。下面的查詢選擇了所有記錄,其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(''''1998-02-03'''');
- 3

WEEKDAY(date)
返回date的星期索引(0=星期一,1=星期二, ……6= 星期天)。
mysql select WEEKDAY(''''1997-10-04 222300'''');
- 5
mysql select WEEKDAY(''''1997-11-05'''');
- 2

DAYOFMONTH(date)
返回date的月份中日期,在1到31范圍內。
mysql select DAYOFMONTH(''''1998-02-03'''');
- 3

DAYOFYEAR(date)
返回date在一年中的日數, 在1到366范圍內。
mysql select DAYOFYEAR(''''1998-02-03'''');
- 34

MONTH(date)
返回date的月份,范圍1到12。
mysql select MONTH(''''1998-02-03'''');
- 2

DAYNAME(date)
返回date的星期名字。
mysql select DAYNAME(1998-02-05);
- ''''Thursday''''

MONTHNAME(date)
返回date的月份名字。
mysql select MONTHNAME(1998-02-05);
- ''''February''''

QUARTER(date)
返回date一年中的季度,范圍1到4。
mysql select QUARTER(''''98-04-01'''');
- 2

WEEK(date)
 
WEEK(date,first)
對於星期天是一周的第一天的地方,有一個單個參數,返回date的周數,范圍在0到52。2個參數形式WEEK()允許
你指定星期是否開始於星期天或星期一。如果第二個參數是0,星期從星期天開始,如果第二個參數是1,
從星期一開始。
mysql select WEEK(''''1998-02-20'''');
- 7
mysql select WEEK(''''1998-02-20'''',0);
- 7
mysql select WEEK(''''1998-02-20'''',1);
- 8

YEAR(date)
返回date的年份,范圍在1000到9999。
mysql select YEAR(''''98-02-03'''');
- 1998

HOUR(time)
返回time的小時,范圍是0到23。
mysql select HOUR(''''100503'''');
- 10

MINUTE(time)
返回time的分鐘,范圍是0到59。
mysql select MINUTE(''''98-02-03 100503'''');
- 5

SECOND(time)
回來time的秒數,范圍是0到59。
mysql select SECOND(''''100503'''');
- 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 分鐘和秒 MINUTESSECONDS
HOUR_MINUTE 小時和分鐘 HOURSMINUTES
DAY_HOUR 天和小時 DAYS HOURS
YEAR_MONTH 年和月 YEARS-MONTHS
HOUR_SECOND 小時, 分鐘, HOURSMINUTESSECONDS
DAY_MINUTE 天, 小時, 分鐘 DAYS HOURSMINUTES
DAY_SECOND 天, 小時, 分鐘, 秒 DAYS HOURSMINUTESSECONDS

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

mysql SELECT 1997-12-31 235959 + INTERVAL 1 SECOND;
- 1998-01-01 000000
mysql SELECT INTERVAL 1 DAY + 1997-12-31;
- 1998-01-01
mysql SELECT 1998-01-01 - INTERVAL 1 SECOND;
- 1997-12-31 235959
mysql SELECT DATE_ADD(1997-12-31 235959,
INTERVAL 1 SECOND);
- 1998-01-01 000000
mysql SELECT DATE_ADD(1997-12-31 235959,
INTERVAL 1 DAY);
- 1998-01-01 235959
mysql SELECT DATE_ADD(1997-12-31 235959,
INTERVAL 11 MINUTE_SECOND);
- 1998-01-01 000100
mysql SELECT DATE_SUB(1998-01-01 000000,
INTERVAL 1 111 DAY_SECOND);
- 1997-12-30 225859
mysql SELECT DATE_ADD(1998-01-01 000000,
INTERVAL -1 10 DAY_HOUR);
- 1997-12-30 140000
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 010203);
- 199907
mysql SELECT EXTRACT(DAY_MINUTE FROM 1999-07-02 010203);
- 20102

如果你指定太短的間隔值(不包括type關鍵詞期望的間隔部分),MySQL假設你省掉了間隔值的最左面部分

copyright © 萬盛學電腦網 all rights reserved