mysql日期時間函數

http://yjsghqqk.blog.163.com/blog/static/4798234120096884444228/html

http://hi.baidu.com/yxl1982/blog/item/d6554e2378fc47549922ed60.htmlmysql

 

MySQL 日期跟時間函數(一)
做者: Mr.Zhang
MySQL 日期跟時間的樣式
在MySQL 中有不少有用處的日期跟時間函數。咱們經常看到許多應用於日期的計算是在代碼
方面上進行的,可是其實他們徹底可使用MySQL中自帶的函數來實 現。在咱們實際的查看MySQL
的時間跟日期函數以前,先讓咱們看看MySQL 的存儲內容。
DATETIME YYYY-MM-DD HH:MM:SS
DATE YYYY-MM-DD
TIMESTAMP YYYYMMDDHHSSMM
TIME HH:MM:SS
YEAR YYYY

TIMESTAMP 欄存儲了全部的14 個字符,可是你其實能夠本身定義他的顯示方式。例如若是
你按照 TIMESTAMP(2)的方式來定義,那麼只會顯示出2 位表示的年份,可是全部的數據仍然是被
保存的。若是往後你想要列出全部的數據的時候, 你只須要改變下限定條件,全部的內容就會顯現
出來。下表就是不一樣的定義以及表現的結果。

TIMESTAMP(14) YYYYMMDDHHMMSS
TIMESTAMP(12) YYMMDDHHMMSS
TIMESTAMP(10) YYMMDDHHMM
TIMESTAMP(8) YYYYMMDD
TIMESTAMP(6) YYMMDD
TIMESTAMP(4) YYMM
TIMESTAMP(2) YY

MySQL 對於所讀入的日期的格式是很是寬容的。雖然MySQL 有使用很廣的約定表現方式,你
仍然能夠改用你喜歡的方式來表現。例如,你建立以下一個 表:

CREATE TABLE time_table(dt DATETIME);
既可使用以下約定的方式插入一條記錄:
INSERT INTO time_table(dt) VALUES('2003-03-31 11:22:12');
也能夠象這樣用’+’和’=’來實 現:
INSERT INTO time_table(dt) VALUES('2003=03=31 11+22+12');
固然,雖然 這種方法可行,可是若是沒有必要,仍是推薦你使用約定的方式。
簡單的日期計算
日期計算很是簡單。咱們首先要查看的一個函數是YEAR() 。For example:
mysql> SELECT YEAR('2003-03-31');
+--------------------+
| YEAR('2003-03-31') |
+--------------------+
| 2003 |
+--------------------+
我 們能夠用「+」,「-」運算符,直接進行一些簡單的運算。例如你要察看該日期5 年後是哪一年,
you can use:
mysql> SELECT YEAR('2003-03-31')+5;
+----------------------+
| YEAR('2003-03-31')+5 |
+----------------------+
| 2008 |
+----------------------+
那 麼同理,5 年前的日期:
mysql> SELECT YEAR('2003-03-31')-5;
+----------------------+
| YEAR('2003-03-31')-5 |
+----------------------+
| 1998 |
+----------------------+
當 然,你也可能有不知道具體時間的時候,MySQL 給你提供了NOW() function:
mysql> SELECT NOW();
+---------------------+
| NOW() |
+---------------------+
| 2003-03-31 00:32:21 |
+---------------------+
或 者CURRENT_DATE() function 只用來提供年月日:
mysql> SELECT CURRENT_DATE();
+----------------+
| CURRENT_DATE() |
+----------------+
| 2003-03-31 |
+----------------+
當 然也有其餘的時間間隔取值函數: MONTH(), DAYOFMONTH(), HOUR(), MINUTE() and
SECOND(). For example:

mysql> SELECT MONTH(NOW()) AS m,
DAYOFMONTH(NOW()) AS d,
HOUR(NOW()) AS h,
MINUTE(NOW()) AS m,
SECOND(NOW()) AS s;
+------+------+------+------+------+
| m | d | h | m | s |
+------+------+------+------+------+
| 3 | 31 | 1 | 53 | 38 |
+------+------+------+------+------+

DAYOFMONTH() function 是命名規範的一個例外,由於他用了其餘的方式返回日期。
DAYOFMONTH() 返回的1-31 的天數,DAYNAME() 返回的是現實中的哪一天, DAYOFWEEK()
返回的是1 (Sunday) to 7(Saturday) , DAYOFYEAR() 返回的是1 到366。
Some examples:
mysql> SELECT DAYNAME('2000-01-01');
+-----------------------+
| DAYNAME('2000-01-01') |
+-----------------------+
| Saturday |
+-----------------------+
mysql> SELECT DAYOFWEEK('2000-01-01');
+-------------------------+
| DAYOFWEEK('2000-01-01') |
+-------------------------+
| 7 |
+-------------------------+
mysql> SELECT DAYOFYEAR('2000-12-31');
+-------------------------+
| DAYOFYEAR('2000-12-31') |
+-------------------------+
| 366 |
+-------------------------+
計 算年齡
最經常使用的日期計算就是年齡計算,不幸得是,並無什麼函數能夠直接實現這個功能,因此這
就須要咱們稍微的動下腦筋,如今讓咱們來作 一些簡單的數學計算--你會發現我從當前時間開始(31
March 2003)。首先,咱們簡單的從當前日期減掉出生日期:
mysql> SELECT YEAR(CURRENT_DATE)-YEAR('1971-01-01');
+---------------------------------------+
| YEAR(CURRENT_DATE)-YEAR('1971-01-01') |
+---------------------------------------+
| 32 |
+---------------------------------------+
若是你直接回復這個數字,那麼明顯的, 計算是正確的。某個出生於1971 年1 月1 日的人到
2003 年3 月31 日是32 歲。可是若是是出生在12 月31 日的人呢:
mysql> SELECT YEAR(CURRENT_DATE)-YEAR('1971-12-31');
+---------------------------------------+
| YEAR(CURRENT_DATE)-YEAR('1971-12-31') |
+---------------------------------------+
| 32 |
+---------------------------------------+
年齡出錯了,這我的尚未到32 歲。問題在於計算的時候只計算了年份,他只用年份相減,
忽視了月份和日期,最好的比較方式仍是要用日期和月份先進行比較,看是否出生日期小於當前 日
期, 若是是這樣,那隻須要計算年份,不然就須要減去一部分年份。這個聽起來很是狡詐,可是事
實上不是。讓咱們慢慢理解一 下,MySQL 中對於TRUE 用1 表示。FALSE 用0 表示的方式對咱們
有很大的幫助,For example:
mysql> SELECT 23>19;
+-------+
| 23>19 |
+-------+
| 1 |
+-------+
mysql> SELECT 23<19;
+-------+
| 23<19 |
+-------+
| 0 |
+-------+
23 >19(true), so MySQL 返回'1', 而且23 不小於19(false), so MySQL 返回'0'。如今咱們
需 要一種方式來返回'MM-DD' 的日期形式, 幸運的是,如今咱們有一個能夠直接使用的函數了,
RIGHT(), 它用於返回從右開始的定義的位數的數值。sql

For example:
mysql> SELECT RIGHT('abcdef',2);
+-------------------+
| RIGHT('abcdef',2) |
+-------------------+
| ef |
+-------------------+
這 樣就返回了從右開始數,2 位的數值'ef '。固然若是你要求的位數超過紀錄的位數,將顯示
所有內容:
mysql> SELECT RIGHT('abcdef',9);
+-------------------+
| RIGHT('abcdef',9) |
+-------------------+
| abcdef |
+-------------------+
所 覺得了返回'MM-DD' 的樣式,你須要返回5 位數據,for example:
mysql> SELECT RIGHT(CURRENT_DATE(),5);
+-------------------------+
| RIGHT(CURRENT_DATE(),5) |
+-------------------------+
| 03-31 |
+-------------------------+
現 在咱們就有了計算一個年齡的全部的數據,能夠用下面的方法來計算了:
mysql> SELECT YEAR(CURRENT_DATE()) - YEAR('1971-12-31')
- (RIGHT(CURRENT_DATE(),5)<'12-31') AS age;
+------+
| age |
+------+
| 31 |
+------+
如今讓咱們來看一些不太常見的函數。首先咱們來看看MySQL 爲這些函數定義的能夠接受的
數據類 型。
SECOND ss
MINUTE mm
HOUR hh
DAY DD
MONTH MM
YEAR YY
MINUTE_SECOND mm:ss
HOUR_MINUTE hh:mm
DAY_HOUR DD:hh
YEAR_MONTH YYYY-MM
HOUR_SECOND hh:ss
DAY_MINUTE DD hh:mm
DAY_SECOND DD hh:mm:ss
就是像你看到的這麼多。事實 上,在你調用程序之前,MySQL 還有不少事情能夠作。
用DATE_ADD()和DATE_SUB() 增長或減小時間和日期
DATE_ADD() function 和ADDDATE() function 具備相同的做用,都是用來在給定的日期和時間上增長一個特定的日期段或時間段,DATE_ADD(日期時間,間隔用日期時間型數據表示的時間
間 隔)。
例如,爲了肯定2003 年七月13 日14 天后的日期,you can use:
mysql> SELECT DATE_ADD('2003-07-13', INTERVAL 14 DAY);
+-----------------------------------------+
| DATE_ADD('2003-07-13', INTERVAL 14 DAY) |
+-----------------------------------------+
| 2003-07-27 |
+-----------------------------------------+ide

相關文章
相關標籤/搜索