欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL timestamp的類型與時區(qū)實例詳解

 更新時間:2016年11月24日 16:07:55   投稿:lqh  
這篇文章主要介紹了 MySQL timestamp的類型與時區(qū)實例詳解的相關資料,需要的朋友可以參考下

 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',該類型的一個重要特點就是保存的時間與時區(qū)密切相關,上述所說的時間范圍是UTC(Universal Time Coordinated)標準,指的是經度0度上的標準時間,我國日常生活中時區(qū)以首都北京所處的東半球第8區(qū)為基準,統(tǒng)一使用東8區(qū)時間(俗稱北京時間),比UTC要早8個小時,服務器的時區(qū)設置也遵照此標準,因此對應過來timestamp的時間范圍則應校準為'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。

需要特點注意,timestamp類型的時間不僅僅與寫入記錄時的時區(qū)有關,顯示時也與時區(qū)有關,例如:

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)

如上述所示,根據時區(qū)的不同,顯示的日期也是不一樣的,這正是timestamp類型在MySQL日期類型中獨有的時區(qū)特點。

如果向timestamp類型列插入的值超出了指定范圍,則實際實際保存的值為'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層面僅是個警告而并非錯誤,前端應用的try catch捕獲不到,不過,由于實際寫入的數據并非期望值,還是有可能埋下一些隱患,這些隱患一旦顯露,就有可能觸發(fā)前端應用出現異常。

  對于timestamp類型,在實際應用中務必理解時區(qū)的概念,在設置timestamp列默認值,及實際賦值時務必明確寫入的值實際保存時的狀態(tài),盡量避免埋入隱患。對于現有已經出錯的記錄,可以考慮通過批量UPDATE及修改表結構的方式予以處理。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關文章

  • mysql 8.0.11 MSI版安裝配置圖文教程

    mysql 8.0.11 MSI版安裝配置圖文教程

    這篇文章主要為大家詳細介紹了mysql 8.0.11 MSI版安裝配置圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • 圖解MySQL中樂觀鎖扣減庫存原理

    圖解MySQL中樂觀鎖扣減庫存原理

    這篇文章主要為大家詳細介紹了MySQL中樂觀鎖扣減庫存原理的相關知識,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-04-04
  • mysql5.7.21.zip安裝教程

    mysql5.7.21.zip安裝教程

    這篇文章主要為大家詳細介紹了mysql5.7.21.zip安裝教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • mysql間隙鎖的具體使用

    mysql間隙鎖的具體使用

    MySQL中有多種鎖類型,本文主要介紹了mysql間隙鎖的具體使用,文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學習學習吧
    2024-02-02
  • MySQL建表設置默認值/取值范圍的操作代碼

    MySQL建表設置默認值/取值范圍的操作代碼

    這篇文章主要介紹了MySQL建表設置默認值/取值范圍的操作代碼,文中給大家提到了MySQL創(chuàng)建表時字符串的默認值,本文給大家講解的非常詳細,需要的朋友可以參考下
    2022-11-11
  • Idea連接MySQL數據庫出現中文亂碼的問題

    Idea連接MySQL數據庫出現中文亂碼的問題

    這篇文章主要介紹了Idea連接MySQL數據庫出現中文亂碼的問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • 關于Win10下MySQL5.7.17免安裝版基本配置教程(圖文詳解)

    關于Win10下MySQL5.7.17免安裝版基本配置教程(圖文詳解)

    這數據庫應用是一個應用系統(tǒng)不可或缺的部分,關系型數據庫應用大同小異,這里選擇MySQL作為數據庫平臺。下面通過本文給大家介紹關于Win10下MySQL5.7.17免安裝版基本配置教程(圖文詳解),需要的朋友可以參考下
    2017-06-06
  • MySQL如何從數據庫中刪除表中所有數據

    MySQL如何從數據庫中刪除表中所有數據

    這篇文章主要介紹了MySQL如何從數據庫中刪除表中所有數據問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Windows安裝MySQL8.0.x 版本教程

    Windows安裝MySQL8.0.x 版本教程

    這篇文章介紹了Windows安裝MySQL8.0.x 版本的方法,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-04-04
  • mysql 8.0.11 winx64安裝配置方法圖文教程

    mysql 8.0.11 winx64安裝配置方法圖文教程

    這篇文章主要為大家詳細介紹了mysql 8.0.11 winx64安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07

最新評論