mysql中的日期類型小結筆記

mysql中的日期類型小結筆記

1.date 和 datetime 的區別

DATE類型 可用於需要一個日期值而不需要時間部分時。
MySQL 以 ‘YYYY-MM-DD’ 格式檢索與顯示DATE值。
支持的範圍是 ‘1000-01-01’ 到 ‘9999-12-31’。


DATETIME類型 可用於需要同時包含日期和時間信息的值。
MySQL 以 ‘YYYY-MM-DD HH:MM:SS’格式檢索與顯示 。
DATETIME 類型支持的範圍是’1000-01-01 00:00:00’ 到 ‘9999-12-31 23:59:59’。
(“支持”的含義是,儘管更早的值可能工作,但不能保證他們均可以。)

2.datetime 和 timestamp 的區別

相同
顯示
TIMESTAMP列的顯示格式與DATETIME列相同。
換句話說,顯示寬度固定在19字符,並且格式爲YYYY-MM-DD HH:MM:SS。

不同
範圍
datetime 以’YYYY-MM-DD HH:MM:SS’格式檢索和顯示DATETIME值。
支持的範圍爲’1000-01-01 00:00:00’到’9999-12-31 23:59:59’TIMESTAMP值不能早於1970或晚於2037

儲存
timestamp
1.4個字節儲存(Time stamp value is stored in 4 bytes)
2.值以UTC格式保存( it stores the number of milliseconds)
3.時區轉化 ,存儲時對當前的時區進行轉換,檢索時再轉換回當前的時區。

datetime
1.8個字節儲存(8 bytes storage)
2.實際格式儲存(Just stores what you have stored and retrieves the same thing which you have stored.)
3.與時區無關(It has nothing to deal with the TIMEZONE and Conversion.)

實例對比
現在我來做個時區對他們的影響。
1.先插入一個數據insert into t8 values(now(), now());
2.改變客戶端時區(東9區,日本時區)。
3.再次顯示插入的數據,變化了,timestamp類型的數據 增加了 1個小時。
在這裏插入圖片描述
接下來 討論一些timestamp 的其他的屬性

1.null 是否爲空
timestamp 默認允許爲 “非空”(not null by default), 如果你在定義“ts TIMESTAMP DEFAULT NULL” 是非法的。
可以指定爲空 null ,“ts TIMESTAMP NULL" ,這時可以在添加語句改變默認值。

ts2 TIMESTAMP NULL DEFAULT 0,
ts3 TIMESTAMP NULL DEFAULT CURRENT_TIMESTAMP

default (一個表中只能有一個列選擇下面其中一種)

default CURRENT_TIMESTAMP
default CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
ON UPDATE CURRENT_TIMESTAMP
ON UPDATE 見上2
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章