MySQL timestamp的類型與時區(qū)實(shí)例詳解
MySQL timestamp的類型與時區(qū)
MySQL的timestamp類型時間范圍between '1970-01-01 00:00:01' and '2038-01-19 03:14:07',超出這個范圍則值記錄為'0000-00-00 00:00:00',該類型的一個重要特點(diǎn)就是保存的時間與時區(qū)密切相關(guān),上述所說的時間范圍是UTC(Universal Time Coordinated)標(biāo)準(zhǔn),指的是經(jīng)度0度上的標(biāo)準(zhǔn)時間,我國日常生活中時區(qū)以首都北京所處的東半球第8區(qū)為基準(zhǔn),統(tǒng)一使用東8區(qū)時間(俗稱北京時間),比UTC要早8個小時,服務(wù)器的時區(qū)設(shè)置也遵照此標(biāo)準(zhǔn),因此對應(yīng)過來timestamp的時間范圍則應(yīng)校準(zhǔn)為'1970-01-01 08:00:01' and '2038-01-19 11:14:07',也就是說東八區(qū)的1970-1-1 08:00:01等同于UTC 1970-1-1 00:00:01。
需要特點(diǎn)注意,timestamp類型的時間不僅僅與寫入記錄時的時區(qū)有關(guān),顯示時也與時區(qū)有關(guān),例如:
mysql> desc j1_dt;
+-------+-----------+------+-----+-------------------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-----------+------+-----+-------------------+-------+
| dt | timestamp | NO | | CURRENT_TIMESTAMP | |
+-------+-----------+------+-----+-------------------+-------+
1 row in set (0.00 sec)
mysql> insert into j1_dt values ('1970-01-01 08:00:01');
Query OK, 1 row affected (0.00 sec)
mysql> select * from j1_dt;
+---------------------+
| dt |
+---------------------+
| 1970-01-01 08:00:01 |
+---------------------+
1 row in set (0.00 sec)
mysql> set time_zone='+0:00';
Query OK, 0 rows affected (0.00 sec)
mysql> select * from j1_dt;
+---------------------+
| dt |
+---------------------+
| 1970-01-01 00:00:01 |
+---------------------+
1 row in set (0.00 sec)
mysql> set time_zone='+1:00';
Query OK, 0 rows affected (0.00 sec)
mysql> select * from j1_dt;
+---------------------+
| dt |
+---------------------+
| 1970-01-01 01:00:01 |
+---------------------+
1 row in set (0.00 sec)
如上述所示,根據(jù)時區(qū)的不同,顯示的日期也是不一樣的,這正是timestamp類型在MySQL日期類型中獨(dú)有的時區(qū)特點(diǎn)。
如果向timestamp類型列插入的值超出了指定范圍,則實(shí)際實(shí)際保存的值為'0000-00-00 00:00:00',并觸發(fā)一個警告信息:
mysql> set time_zone='+8:00';
Query OK, 0 rows affected (0.00 sec)
mysql> select * from j1_dt;
+---------------------+
| dt |
+---------------------+
| 1970-01-01 08:00:01 |
+---------------------+
1 row in set (0.00 sec)
mysql> insert into j1_dt values ('1970-01-01 00:00:01');
Query OK, 1 row affected, 1 warning (0.00 sec)
mysql> show warnings;
+---------+------+------------------------------------------------------+
| Level | Code | Message |
+---------+------+------------------------------------------------------+
| Warning | 1264 | Out of range value adjusted for column 'dt' at row 1 |
+---------+------+------------------------------------------------------+
1 row in set (0.00 sec)
mysql> select * from j1_dt;
+---------------------+
| dt |
+---------------------+
| 1970-01-01 08:00:01 |
| 0000-00-00 00:00:00 |
+---------------------+
2 rows in set (0.00 sec)
觸發(fā)的警告信息在MySQL層面僅是個警告而并非錯誤,前端應(yīng)用的try catch捕獲不到,不過,由于實(shí)際寫入的數(shù)據(jù)并非期望值,還是有可能埋下一些隱患,這些隱患一旦顯露,就有可能觸發(fā)前端應(yīng)用出現(xiàn)異常。
對于timestamp類型,在實(shí)際應(yīng)用中務(wù)必理解時區(qū)的概念,在設(shè)置timestamp列默認(rèn)值,及實(shí)際賦值時務(wù)必明確寫入的值實(shí)際保存時的狀態(tài),盡量避免埋入隱患。對于現(xiàn)有已經(jīng)出錯的記錄,可以考慮通過批量UPDATE及修改表結(jié)構(gòu)的方式予以處理。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
MySQL建表設(shè)置默認(rèn)值/取值范圍的操作代碼
這篇文章主要介紹了MySQL建表設(shè)置默認(rèn)值/取值范圍的操作代碼,文中給大家提到了MySQL創(chuàng)建表時字符串的默認(rèn)值,本文給大家講解的非常詳細(xì),需要的朋友可以參考下2022-11-11
Idea連接MySQL數(shù)據(jù)庫出現(xiàn)中文亂碼的問題
這篇文章主要介紹了Idea連接MySQL數(shù)據(jù)庫出現(xiàn)中文亂碼的問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04
關(guān)于Win10下MySQL5.7.17免安裝版基本配置教程(圖文詳解)
這數(shù)據(jù)庫應(yīng)用是一個應(yīng)用系統(tǒng)不可或缺的部分,關(guān)系型數(shù)據(jù)庫應(yīng)用大同小異,這里選擇MySQL作為數(shù)據(jù)庫平臺。下面通過本文給大家介紹關(guān)于Win10下MySQL5.7.17免安裝版基本配置教程(圖文詳解),需要的朋友可以參考下2017-06-06
MySQL如何從數(shù)據(jù)庫中刪除表中所有數(shù)據(jù)
這篇文章主要介紹了MySQL如何從數(shù)據(jù)庫中刪除表中所有數(shù)據(jù)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06

