MySQL中的多種時間和格式數據類型


日期和時間類型是為了方便在數據庫中存儲日期和時間而設計的。MySQL中有多種表示日期和時間的數據類型。

 

 

 

關於上圖的解釋:

1)每種日期和時間類型都有一個有效范圍。如果插入的值超過了這個范圍,系統就會報錯,並將0值插入到數據庫中。

2)不同的日期與時間類型有不同的0值,上表中已經詳細的列出。

1、year類型

year類型使用1個字節來表示年份,MySQL中以YYYY的形式來顯示year類型的值。

給year類型的字段賦值的表示方法如下:

1)使用4位字符串和數字表示。其范圍從1901~~2155。輸入格式為'YYYY'或YYYY。舉個例子,輸入‘2008’或者2008,可直接保存2008。如果超過了范圍,就會插入0000。

2)使用2位字符串表示。‘00’~~‘69’轉換為2000~~2069,‘70’~~‘99’轉換為1970~1999。舉個例子,輸入‘35’,year值會轉換成2035,輸入‘90’,year值會轉換成1990。‘0’和‘00’效果一樣。

3)使用2位數字表示。1~~69轉換為2001~~2069,70~~99轉換為1970~~1999。不舉例子了,注意,2位數字和2位字符串是不一樣的。如果插入0,轉換后的year值不是2000,而是0000。

OK,針對上面的例子,我們來實際操作下數據庫。

CREATE TABLE  `linkinframe`.`test` (
 `id` INT NOT NULL,
`a` year NULL,
PRIMARY KEY (`id`));

現在往該表中插入幾條數據:

INSERT INTO `linkinframe`.`test` (`id`, `a`)  VALUES('1',1989);
INSERT INTO `linkinframe`.`test` (`id`, `a`)  VALUES('2,1990);
INSERT INTO `linkinframe`.`test` (`id`, `a`)  VALUES('3',1900);
INSERT INTO `linkinframe`.`test` (`id`, `a`)  VALUES('4',2156);

year類型是使用總結:

1)顧名思義,我們一般用year類型來表示年份,所以在對該字段進行相關操作的時候,最好使用4位字符串或者數字表示,不要使用2位的字符串和數字。

2)有的時候可能會插入0或者‘0’。這里要嚴格區分0和‘0’,如果向year類型的字段插入0,存入該字段的年份是0000;如果向year類型的字段插入‘0’,存入的年份是2000。

當然字符串‘0’和‘00’和‘000’是一樣的效果,但是‘0000’效果不一樣。因為如果是4個0的話就使用了year類型賦值的第一種方式,也就是超過了year類型的范圍,插入了0。

關於這點這里來舉一個實際的例子吧。

 

2、time類型

time類型使用3個字節來表示時間。MySQL中以HH:MM:SS的形式顯示Time類型的值。其中,HH表示時;MM表示分,取值范圍為0~~59;SS表示秒,取值范圍是0~~59。
Time類型的范圍可以從‘-838:59:59’~~‘838:59:59’。雖然,小時的范圍是0~~23,但是為了表示某種特殊需要的時間間隔,將Time類型的范圍擴大了。而且還支持了負值。

Time類型的字段賦值的表示方法如下:

1)‘D HH:MM:SS’格式的字符串表示。其中,D表示天數,取值范圍是0~~34。保存時,小時的值等於(D*24+HH)。舉個例子,輸入‘2 11:30:50’,Time類型會轉換為59:30:50。
當然。輸入時可以不嚴格按照這個格式,也可以是‘HH:MM:SS’,'HH:MM','D HH:MM','D HH','SS'等形式。舉個例子,輸入‘30’,Time類型會自動轉換為00:00:30。

2)‘HHMMSS’格式的字符串或HHMMSS格式的數值表示,例如,輸入‘123456’,Time類型會轉換成12:34:56;輸入123456,Time類型會轉換成12:34:56。如果輸入0或者‘0’,那么TIME類型會轉換為0000:00:00。

3)使用current_time或者current_time()或者now()輸入當前系統時間。

 

3、Date類型

date類型使用4個字節來表示日期。MySQL中是以YYYY-MM-DD的形式顯示date類型的值。
其中,YYYY表示年,MM表示月,DD表示日。date類型的范圍可以從‘1000-01-01’~~‘9999-12-31’。

給DATE類型的字段賦值的表示方法如下:

1)‘YYYY-MM-DD’或‘YYYYMMDD’格式的字符串表示,這種方式可以表達的范圍是‘1000-01-01’~‘9999-12-31’。
舉個例子,比如現在我輸入‘4008-2-8‘,date類型將轉換為4008-02-08;輸入’40080308‘,date類型將轉換為4008-03-08。

2)當然,MySQL中還支持一些不嚴格的語法格式,任何標點都可以用來做間隔符。如’YYYY/MM/DD‘,’YYYY@MM@DD‘,’YYYY.MM.DD‘等分隔形式。
舉個例子,輸入’2011.3.8‘,date類型將轉換為2011-03-08。

3)’YY-MM-DD‘或者’YYMMDD‘格式的字符串表示,其中’YY‘的取值,’00‘~~’69‘轉換為2000~~2069,’70‘~~’99‘轉換為1970~~1999。與year類型類似。
舉個例子,比如現在我輸入’35-01-02‘,date類型將轉換為2035-01-02;輸入’800102‘,date類型將轉換為1980-01-02。

4)同樣的,MySQL中也支持一些不嚴格的語法格式,比如’YY/MM/DD‘,’YY@MM@DD‘,’YY.MM.DD’等分隔形式。例如,輸入‘89@3@8’,date類型將轉換為1989-03-08。

5)YYYYMMDD或YYMMDD格式的數字表示。其中,‘YY’的取值,‘00’~~‘69’轉換為2000~~2069,‘70’~~‘99’轉換為1970~~1999。與year類型類似。
舉個例子,比如現在我輸入20080808,date類型將轉換為2008-08-08;輸入790808,date類型將轉換為1979-08-08;輸入0,那么date類型會轉化為0000-00-00。

6)使用current_date或now()來輸入當前系統時間。

關於date類型的總結:

1)date類型值戰友4個字節,如果只需要記錄日期,選擇date類型是最合適的。
2)雖然MySQL支持的DATA類型的一些不嚴格的語法格式,但是,在實際應用中,最好還是選擇標准形式。日期中使用“-”做分隔符,時間用“:”做分隔符,然后中間用空格隔開。

比如下面格式:2016-03-17 16:27:55。當然如果有特殊需要,可以使用“@”,“*”等特殊字符做分隔符。

 

4、Datetime類型

datetime類型使用8個字節來表示日期和時間。MySQL中以‘YYYY-MM-DD HH:MM:SS’的形式來顯示dateTime類型的值。
從其形式上可以看出,dateTime類型可以直接用date類型和Time類型組合而成。

給dateTime類型的字段賦值的表示方法如下:

1)‘YYYY-MM-DD HH:MM:SS’或‘YYYYMMDDHHMMSS’格式的字符串表示。這種方式可以表達的范圍是‘1000-01-01 00:00:00’~~‘9999-12-31 23:59:59’。
舉個例子,比如我現在輸入‘2008-08-08 08:08:08’,dateTime類型轉換為2008-08-08 08:08:08,輸入‘20080808080808’,同樣轉換為2008-08-08 08:08:08。

2)MySQL中還支持一些不嚴格的語法格式,任何的標點都可以用來做間隔符。情況與date類型相同,而且時間部分也可以使用任意的分隔符隔開,這與Time類型不同,Time類型只能用‘:’隔開呢。
舉個例子,比如我現在輸入‘2008@08@08 08*08*08’,數據庫中dateTime類型統一轉換為2008-08-08 08:08:08。

3)‘YY-MM-DD HH:MM:SS’或‘YYMMDDHHMMSS’格式的字符串表示。其中‘YY’的取值,‘00’~~‘69’轉換為2000~~2069,‘70’~~‘99’轉換為1970~~1999。與year型和date型相同。
舉個例子,比如我現在輸入‘69-01-01 11:11:11’,數據庫中插入2069-01-01 11:11:11;比如我現在輸入‘70-01-01 11:11:11’,數據庫中插入1970-01-01 11:11:11。

4)當然這種格式化的省略YY的簡寫也是支持一些不嚴格的語法格式的,比如用‘@’,‘*’來做間隔符。

5)使用now()來輸入當前系統日期和時間。

datetime類型總結:

dateTime類型用來記錄日期和時間,其作用等價於date類型和Time類型的組合。一個dateTime類型的字段可以用一個date類型的字段和一個time類型的字段代替。但是如果需要同時記錄日期和時間,選擇dateTime類型是個不錯的選擇。

 

5、timestamp類型

timestamp類型使用4個字節來表示日期和時間。timestamp類型的范圍是從1970-01-01 08:00:01~~2038-01-19 11:14:07。

MySQL中也是以‘YYYY-MM-DD HH:MM:SS’的形式顯示timestamp類型的值。從其形式可以看出,timestamp類型與dateTime類型顯示的格式是一樣的。

給timestamp類型的字段復制的表示方法基本與dateTime類型相同。值得注意的是,timestamp類型范圍比較小,沒有dateTime類型的范圍那么大。所以輸入值時要保證在timestamp類型的有效范圍內。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM