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假設你省掉了間隔值的最左面部分