mysql之TIMESTAMP(時間戳)用法詳解

2021-09-29 21:02:50 字數 2604 閱讀 5770

timestamp資料型別是乙個比較特殊的資料型別,他可以自動在你不使用程式更新情況下只要你更新了記錄timestamp會自動更新時間.

通常表中會有乙個create date 建立日期的字段,其它資料庫均有預設值的選項。mysql也有預設值timestamp,但在mysql中,不僅是插入就算是修改也會更新timestamp的值!

這樣一來,就不是建立日期了,當作更新日期來使用比較好!

一、timestamp的變體

timestamp時間戳在建立的時候可以有多重不同的特性,如:

1.在建立新記錄和修改現有記錄的時候都對這個資料列重新整理:

timestampdefaultcurrent_timestamponupdatecurrent_timestamp

2.在建立新記錄的時候把這個字段設定為當前時間,但以後修改時,不再重新整理它:

timestampdefaultcurrent_timestamp

3.在建立新記錄的時候把這個字段設定為0,以後修改時重新整理它:

timestamponupdatecurrent_timestamp

4.在建立新記錄的時候把這個字段設定為給定值,以後修改時重新整理它:

timestampdefault『yyyy-mm-dd hh:mm:ss'onupdatecurrent_timestamp

mysql目前不支援列的default 為函式的形式,如達到你某列的預設值為當前更新日期與時間的功能,你可以使用timestamp列型別,下面就詳細說明timestamp列型別

二、timestamp列型別

timestamp值可以從1970的某時的開始一直到2023年,精度為一秒,其值作為數字顯示。

timestamp值顯示尺寸的格式如下表所示:

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

| 列型別    | 顯示格式    |

|timestamp(14) | yyyymmddhhmmss |

|timestamp(12) | yymmddhhmmss  |

|timestamp(10) | yymmddhhmm   |

|timestamp(8) | yyyymmdd    |

|timestamp(6) | yymmdd     |

|timestamp(4) | yymm      |

|timestamp(2) | yy       |

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

「完整」timestamp格式是14位,但timestamp列也可以用更短的顯示尺寸,創造最常見的顯示尺寸是6、8、12、和14。

你可以在建立表時指定乙個任意的顯示尺寸,但是定義列長為0或比14大均會被強制定義為列長14。

列長在從1~13範圍的奇數值尺寸均被強制為下乙個更大的偶數。

列如:定義字段長度   強制字段長度

timestamp(0) ->timestamp(14)

timestamp(15)->timestamp(14)

timestamp(1) ->timestamp(2)

timestamp(5) ->timestamp(6)

1.雖然你建表時定義了列timestamp(8),但在你進行資料插入與更新時timestamp列實際上儲存了14位的資料(包括年月日時分秒),只不過在你進行查詢時mysql返回給你的是8位的年月日資料。如果你使用alter table拓寬乙個狹窄的timestamp列,以前被「隱蔽」的資訊將被顯示。

2.同樣,縮小乙個timestamp列不會導致資訊失去,除了感覺上值在顯示時,較少的資訊被顯示出。

mysql之TIMESTAMP(時間戳)用法詳解

timestamp資料型別是乙個比較特殊的資料型別,他可以自動在你不使用程式更新情況下只要你更新了記錄timestamp會自動更新時間.通常表中會有乙個create date 建立日期的字段,其它資料庫均有預設值的選項。mysql也有預設值timestamp,但在mysql中,不僅是插入就算是修改也...

mysql 建立日期列之timestamp

mysql 有很多日期格式 這裡僅說明timestamp的應用 mysql create table t1 id int,b timestamp default current timestamp query ok,0 rows affected 0.19 sec mysql show create...

mysql之TIMESTAMP(時間戳)用法詳解

timestamp資料型別是乙個比較特殊的資料型別,他可以自動在你不使用程式更新情況下只要你更新了記錄timestamp會自動更新時間.通常表中會有乙個create date 建立日期的字段,其它資料庫均有預設值的選項。mysql也有預設值timestamp,但在mysql中,不僅是插入就算是修改也...