日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql 时间 1_(转)mysql日期时间函数1

發布時間:2023/12/3 数据库 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql 时间 1_(转)mysql日期时间函数1 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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(), 它用于返回從右開始的定義的位數的數值。

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)

+------+

| 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 |

+-----------------------------------------+

總結

以上是生活随笔為你收集整理的mysql 时间 1_(转)mysql日期时间函数1的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。