【MySQL】explicit_defaults_for_timestamp 參數詳解


簡介:
explicit_defaults_for_timestamp 系統變量決定MySQL服務端對timestamp列中的默認值和NULL值的不同處理方法。

此變量自MySQL 5.6.6 版本引入,分為全局級別和會話級別,可動態更新,默認值為OFF。本文主要介紹該參數打開和關閉情況下對timestamp的影響 。

1.explicit_defaults_for_timestamp = OFF

當該參數默認設置為OFF時,其行為如下:

在默認情況下,如果timestamp列沒有顯式的指明null屬性,那么該列會被自動加上not null屬性(而其他類型的列如果沒有被顯式的指定not null,那么是允許null值的),如果往這個列中插入null值,會自動的設置該列的值為current timestamp值。

表中的第一個timestamp列,如果沒有指定null屬性或者沒有指定默認值,也沒有指定ON UPDATE語句。那么該列會自動被加上DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP屬性。

對於其它TIMESTAMP列,如果沒有顯示指定NULL和DEFAULT屬性的話,會自動設置為NOT NULL DEFAULT ‘0000-00-00 00:00:00’。

(當然,這個與SQL_MODE有關,如果SQL_MODE中包含’NO_ZERO_DATE’,實際上是不允許將其默認值設置為’0000-00-00 00:00:00’的。)

下面我們來測試下:(本文操作基於MySQL5.7.23 版本 SQL_MODE不包含’NO_ZERO_DATE’)

show variables like 'explicit_defaults_for_timestamp';

 

 

create table test (
      col1 timestamp,
      col2 timestamp,
      col3 timestamp default '2010-01-01 00:00:00'
      );

我們查看創建的表:

 

show create table test;

insert into test values (null,null,null);

MySQL自動為第一個timestamp字段自動設置NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP屬性;

而后面的timestamp字段,雖然設置了 **NOT NULL DEFAULT ‘0000-00-00 00:00:00’**屬性,如果向timestamp這個列中插入null值,系統會自動的設置該列的值為current timestamp值。

綜上所述:

當explicit_defaults_for_timestamp=OFF時,即使timestamp列設為NOT NULL也能插入NULL值,系統會自動將NULL值設為current timestamp。

2.explicit_defaults_for_timestamp = ON

my.ini配置文件中,添加了該項配置,否則啟動時,會提示以下報警:

[Warning] TIMESTAMP with implicit DEFAULT value is deprecated.
Please use --explicit_defaults_for_timestamp server option (see
documentation for more details).

但是我在華為的實例中root權限:

 

當該參數設置為ON時,其行為如下:

  1. 如果timestamp列沒有顯式的指定not null屬性,那么默認的該列可以為null,此時向該列中插入null值時,會直接記錄null,而不是current timestamp。
  2. 不會自動的為表中的第一個timestamp列加上DEFAULT CURRENT_TIMESTAMP 和ON UPDATE CURRENT_TIMESTAMP屬性。
  3. 如果timestamp列被加上了not null屬性,並且沒有指定默認值。這時如果向表中插入記錄,但是沒有給該TIMESTAMP列指定值的時候,如果strict sql_mode被指定了,那么會直接報錯。
  4. 如果strict sql_mode沒有被指定,那么會向該列中插入’0000-00-00 00:00:00’並且產生一個warning。

同樣的,我們來測試一下,為了測試我把我的本地計算的mysql5.5卸載重新安裝5.7,一段操作猛如虎:

mysql> show variables like 'explicit_defaults_for_timestamp';
+---------------------------------+-------+
| Variable_name                   | Value |
+---------------------------------+-------+
| explicit_defaults_for_timestamp | OFF   |
+---------------------------------+-------+
1 row in set, 1 warning (0.00 sec)

mysql> set explicit_defaults_for_timestamp=1;
Query OK, 0 rows affected (0.00 sec)

mysql> show variables like 'explicit_defaults_for_timestamp';
+---------------------------------+-------+
| Variable_name                   | Value |
+---------------------------------+-------+
| explicit_defaults_for_timestamp | ON    |
+---------------------------------+-------+
1 row in set, 1 warning (0.00 sec)

mysql> use test;
Database changed

mysql> create table test (
    ->       col1 timestamp,
    ->       col2 timestamp,
    ->       col3 timestamp default '2010-01-01 00:00:00'
    ->       );
Query OK, 0 rows affected (0.02 sec)

mysql> insert into test values (null,null,null);
Query OK, 1 row affected (0.01 sec)

mysql> select * from test;
+------+------+------+
| col1 | col2 | col3 |
+------+------+------+
| NULL | NULL | NULL |
+------+------+------+
1 row in set (0.00 sec)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM