<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
這個世界離不開時間,同樣,資料庫中也是如此,表中的每條記錄除了資料模型的時間欄位(如生日,生產日期,出發日期等),一般至少還有兩個固定的時間欄位:記錄插入時間,記錄更新時間。
然而,看似很簡單時間欄位,誰能想到會導致應用報錯,引發血案:
箇中緣由,正是接下來要講到的。
因時間欄位的一些特性與版本有關,且目前我司統一使用的mysql 5.7版本,因此本文內容都基於mysql 5.7。
mysql時間相關的欄位主要有DATE、DATETIME、TIMESTAMP。
其中datatime和timestamp欄位都可以包含小數,如datetime(6),位元組長度的可變部分(0-3)由小數位數決定:
DATE:
3個位元組的整型,按照這種方式進行壓縮: YYYY×16×32 + MM×32 + DD
DATETIME:
整數部分5個位元組,由以下部分組成
TIMESTAMP:
整數部分4個位元組,儲存從(‘1970-01-01 00:00:00’ UTC)到指定時間的秒數;
timestamp型別是4個位元組,最大值是2的31次方減1,也就是2147483647,轉換成北京時間就是2038-01-19 11:14:07
admin@test 04:42:41>show variables like 'time_zone'; +---------------+--------+ | Variable_name | Value | +---------------+--------+ | time_zone | +08:00 | +---------------+--------+ admin@test 04:42:42>create table t1(dt datetime,ts timestamp); admin@test 04:43:07>insert into t1 values(now(),now()); admin@test 04:43:17>select * from t1; +---------------------+---------------------+ | dt | ts | +---------------------+---------------------+ | 2021-03-27 16:43:17 | 2021-03-27 16:43:17 | +---------------------+---------------------+ admin@test 04:43:50>set time_zone='+09:00'; admin@test 04:44:00>select * from t1; +---------------------+---------------------+ | dt | ts | +---------------------+---------------------+ | 2021-03-27 16:43:17 | 2021-03-27 17:43:17 | +---------------------+---------------------+ admin@test 04:44:07>
timestamp在處理預設值和null值時的行為時受mysql引數explicit_defaults_for_timestamp控制,datatime不受影響。
當禁用該值時(explicit_defaults_for_timestamp=0),mysql啟用timestamp欄位的特有行為(和數位、字串等型別的表現不同),
具體特性如下:
admin@test 05:49:00>create table t2(id int auto_increment, name varchar(100), dt1 datetime, ts1 timestamp, ts2 timestamp, primary key(id)); admin@test 05:49:48>show create table t2; ±------±--------------------------------------------------------------------------+ | Table | Create Table | ±------±--------------------------------------------------------------------------+ | t2 | CREATE TABLE t2 ( id int(11) NOT NULL AUTO_INCREMENT, name varchar(100) DEFAULT NULL, dt1 datetime DEFAULT NULL, ts1 timestamp NULL DEFAULT NULL, ts2 timestamp NULL DEFAULT NULL, PRIMARY KEY (id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 | ±------±--------------------------------------------------------------------------+ 1 row in set (0.00 sec) admin@test 05:50:20>insert into t2(name) values(‘a1'); Query OK, 1 row affected (0.00 sec) admin@test 05:51:07>select * from t2; ±—±-----±-----±-----±-----+ | id | name | dt1 | ts1 | ts2 | ±—±-----±-----±-----±-----+ | 1 | a1 | NULL | NULL | NULL | ±—±-----±-----±-----±-----+ 1 row in set (0.00 sec) ##注:插入記錄時,預設為null admin@test 05:54:20>update t2 set name=‘aa1' where id=1; Query OK, 1 row affected (0.00 sec) Rows matched: 1 Changed: 1 Warnings: 0 admin@test 05:54:31>select * from t2; ±—±-----±-----±-----±-----+ | id | name | dt1 | ts1 | ts2 | ±—±-----±-----±-----±-----+ | 1 | aa1 | NULL | NULL | NULL | ±—±-----±-----±-----±-----+ 1 row in set (0.00 sec) ##注:更新記錄時,預設為null admin@test 05:58:10>create table t3(id int auto_increment,name varchar(100),ts1 timestamp not null default current_timestamp,primary key(id)); admin@test 05:58:18>insert into t3(name) values(‘a1'); Query OK, 1 row affected (0.00 sec) admin@test 05:58:22>select * from t3; ±—±-----±--------------------+ | id | name | ts1 | ±—±-----±--------------------+ | 1 | a1 | 2021-03-23 17:58:22 | ±—±-----±--------------------+ 1 row in set (0.00 sec) ##注:建立表手動設定not null default current_timestamp,插入記錄不含timestamp欄位時,預設為當前時間 admin@test 05:58:25>insert into t3(name,ts1) values(‘a1',null); ERROR 1048 (23000): Column ‘ts1' cannot be null ##注:timestamp欄位顯式插入null時,報錯Column ‘ts1' cannot be null admin@test 05:59:11>create table t4(id int auto_increment,name varchar(100),ts1 timestamp not null ,primary key(id)); Query OK, 0 rows affected (0.04 sec) admin@test 05:59:44>insert into t4(name) values(‘a1'); ERROR 1364 (HY000): Field ‘ts1' doesn't have a default value admin@test 05:59:49> ##注:建立表手動設定not null,插入記錄不含timestamp欄位時,報錯Field doesn't have a default value admin@test 05:59:50>insert into t4(name,ts1) values(‘a1',null); ERROR 1048 (23000): Column ‘ts1' cannot be null admin@test 05:59:57> ##注:timestamp欄位顯式插入null時,報錯Column ‘ts1' cannot be null
當啟用該值時(explicit_defaults_for_timestamp=1),mysql禁用timestamp欄位的特有行為,具體表現和數位、字串型別一樣。
admin@test 05:49:00>create table t2(id int auto_increment, name varchar(100), dt1 datetime, ts1 timestamp, ts2 timestamp, primary key(id)); admin@test 05:49:48>show create table t2; +-------+---------------------------------------------------------------------------+ | Table | Create Table | +-------+---------------------------------------------------------------------------+ | t2 | CREATE TABLE `t2` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(100) DEFAULT NULL, `dt1` datetime DEFAULT NULL, `ts1` timestamp NULL DEFAULT NULL, `ts2` timestamp NULL DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 | +-------+---------------------------------------------------------------------------+ 1 row in set (0.00 sec) admin@test 05:50:20>insert into t2(name) values(‘a1'); Query OK, 1 row affected (0.00 sec) admin@test 05:51:07>select * from t2; ±—±-----±-----±-----±-----+ | id | name | dt1 | ts1 | ts2 | ±—±-----±-----±-----±-----+ | 1 | a1 | NULL | NULL | NULL | ±—±-----±-----±-----±-----+ 1 row in set (0.00 sec) ## 注:插入記錄時,預設為null admin@test 05:54:20>update t2 set name=‘aa1' where id=1; Query OK, 1 row affected (0.00 sec) Rows matched: 1 Changed: 1 Warnings: 0 admin@test 05:54:31>select * from t2; ±—±-----±-----±-----±-----+ | id | name | dt1 | ts1 | ts2 | ±—±-----±-----±-----±-----+ | 1 | aa1 | NULL | NULL | NULL | ±—±-----±-----±-----±-----+ 1 row in set (0.00 sec) ## 注:更新記錄時,預設為null admin@test 05:58:10>create table t3(id int auto_increment,name varchar(100),ts1 timestamp not null default current_timestamp,primary key(id)); admin@test 05:58:18>insert into t3(name) values(‘a1'); Query OK, 1 row affected (0.00 sec) admin@test 05:58:22>select * from t3; ±—±-----±--------------------+ | id | name | ts1 | ±—±-----±--------------------+ | 1 | a1 | 2021-03-23 17:58:22 | ±—±-----±--------------------+ 1 row in set (0.00 sec) ##注:建立表手動設定not null default current_timestamp,插入記錄不含timestamp欄位時,預設為當前時間 admin@test 05:58:25>insert into t3(name,ts1) values(‘a1',null); ERROR 1048 (23000): Column ‘ts1' cannot be null ##注:timestamp欄位顯式插入null時,報錯Column ‘ts1' cannot be null admin@test 05:59:11>create table t4(id int auto_increment,name varchar(100),ts1 timestamp not null ,primary key(id)); Query OK, 0 rows affected (0.04 sec) admin@test 05:59:44>insert into t4(name) values(‘a1'); ERROR 1364 (HY000): Field ‘ts1' doesn't have a default value admin@test 05:59:49> ##注:建立表手動設定not null,插入記錄不含timestamp欄位時,報錯Field doesn't have a default value admin@test 05:59:50>insert into t4(name,ts1) values(‘a1',null); ERROR 1048 (23000): Column ‘ts1' cannot be null admin@test 05:59:57> ##注:timestamp欄位顯式插入null時,報錯Column ‘ts1' cannot be null
啟用該引數(explicit_defaults_for_timestamp=1)
timestamp欄位在null、default屬性的表現和其他普通欄位表現類似:
禁用該引數(explicit_defaults_for_timestamp=0)
timestamp欄位在null、default屬性的表現和其他普通欄位表現有明顯差異:
案例發生的場景:
公司所有叢集已經統一啟用該引數;
某叢集過去某個時間因為研發的要求,將該引數禁用,但是這次叢集切換後的新伺服器採用了統一的引數模板,啟用了引數;
應用程式顯式向timestamp欄位插入null值,且該欄位已經設定了not null,在禁用該引數的叢集不會報錯,但是切換到啟用了該引數的叢集時,就報column cannot be null.
統一規範:
個別叢集禁用該引數導致公司所有的mysql叢集引數不統一,可能帶來應用報錯的後果,因此建議:
到此這篇關於mysql timestamp欄位規範使用詳情的文章就介紹到這了,更多相關mysql timestamp欄位 內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45