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

MySQL遷移中explicit_defaults_for_timestamp參數(shù)影響

 更新時間:2024年09月09日 10:51:35   作者:Bing@DBA  
在MySQL數(shù)據(jù)庫遷移過程中,explicit_defaults_for_timestamp參數(shù)設置為off可能導致數(shù)據(jù)寫入行為變化,本文就來介紹一下explicit_defaults_for_timestamp參數(shù)影響,感興趣的可以了解一下

前言

最近在做數(shù)據(jù)遷移的時候,使用的是云平臺自帶的同步工具,在預檢查階段,當時報錯 explicit_defaults_for_timestamp 參數(shù)在目標端為 off 建議修改 on,有什么風險呢?在此記錄下。

測試對比

MySQL 默認情況下 explicit_defaults_for_timestamp = 0 我們對比一下看看。

explicit_defaults_for_timestamp = 0

在 explicit_defaults_for_timestamp 參數(shù)等于 0 的狀態(tài)下,如果第一個 timestamp 類型的字段如果沒有設置 null 將會自動加上 not null 和默認值。如果設置了默認值,則會自動加上 not null,其他類型的字段是不會的。

create table test03 (
    a_time timestamp ,
    b_time timestamp null ,
    c_time timestamp default '2024-01-01 00:00:00',
    name varchar(2) default 'a');

show create table test03;

CREATE TABLE `test03` (
  `a_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `b_time` timestamp NULL DEFAULT NULL,
  `c_time` timestamp NOT NULL DEFAULT '2024-01-01 00:00:00',
  `name` varchar(2) DEFAULT 'a'
) ENGINE=InnoDB DEFAULT CHARSET=latin1

然后,我們嘗試插入一個記錄:

insert into test03 values (null, null, null, null);
a_timeb_timec_timename
2024-09-05 14:37:12NULL2024-09-05 14:37:12NULL

可以看到,在 explicit_defaults_for_timestamp 等于 0 的時候,不僅會影響表結(jié)構(gòu),還會影響寫入。雖然 timestamp 是 not null 我們寫入 null 后變?yōu)榱?CURRENT_TIMESTAMP。

如果此時將參數(shù)設置為 1,執(zhí)行相同的 SQL 語句則會報錯:

# 設置參數(shù)為 1
set global explicit_defaults_for_timestamp = 1;

# 插入相同的數(shù)據(jù)
insert into test03 values (null, null, null, null);

[23000][1048] Column ‘a_time’ cannot be null

explicit_defaults_for_timestamp = 1

此時在 explicit_defaults_for_timestamp 等于 1 的條件下,執(zhí)行一個剛才的建表語句:

create table test04 (
    a_time timestamp ,
    b_time timestamp null ,
    c_time timestamp default '2024-01-01 00:00:00',
    d_time timestamp not null );

show create table test04;

CREATE TABLE `test04` (
  `a_time` timestamp NULL DEFAULT NULL,
  `b_time` timestamp NULL DEFAULT NULL,
  `c_time` timestamp NULL DEFAULT '2024-01-01 00:00:00',
  `d_time` timestamp NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1

嘗試插入數(shù)據(jù):

insert into test04 values (null, null, null, null);
a_timeb_timec_timename
NULLNULLNULLNULL

從上面可以看到,參數(shù)開啟的情況下,MySQL 默認會為 timestamp 為 NULL 的字段添加 default null 屬性。而且 MySQL 沒有為第一個 timestamp 設置默認值,當我寫入 null 后,則按照 null 來存儲。

另外,如果 timestamp 設置為 not null 那么寫入 null 時會報錯,如果 sql_mode 中不包含 SQL_MODE 的話,則存儲為 ‘0000-00-00 00:00:00’ 并拋出一個異常。

總結(jié)

生產(chǎn)環(huán)境 timestamp 字段一般都會設置為如下樣式,而且需要 timestamp 字段為 null 的業(yè)務場景很少。

`created_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '更新時間',
`updated_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新時間',

如果生產(chǎn)環(huán)境,要修改這個參數(shù),從 0 調(diào)整到 1 需要關注的就是 insert 語句,有沒有直接圖省事插入 null 表示當前時間,如果有這種不規(guī)范的語法,那么調(diào)整該參數(shù)后,可能會報錯。

云平臺一般不會給用戶 super 賬號,所以在遷移過程中,可能無法設置 session 級別的參數(shù),此時建議跳過該校驗,不修改全局級別的參數(shù)。

到此這篇關于MySQL 遷移中 explicit_defaults_for_timestamp參數(shù)影響的文章就介紹到這了,更多相關MySQL explicit_defaults_for_timestamp參數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • MYSQL初學者命令行使用指南

    MYSQL初學者命令行使用指南

    其實MYSQL的對數(shù)據(jù)庫的操作與其它的SQL類數(shù)據(jù)庫大同小異,您最好找本將SQL的書看看。我在這里只介紹一些基本的,其實我也就只懂這些了,呵呵。最好的MYSQL教程還是“晏子“譯的“MYSQL中文參考手冊“不僅免費每個相關網(wǎng)站都有下載,而且它是最權(quán)威的。
    2008-06-06
  • 淺談MySQL存儲引擎選擇 InnoDB與MyISAM的優(yōu)缺點分析

    淺談MySQL存儲引擎選擇 InnoDB與MyISAM的優(yōu)缺點分析

    MyISAM 是MySQL中默認的存儲引擎,一般來說不是有太多人關心這個東西。決定使用什么樣的存儲引擎是一個很tricky的事情,但是還是值我們?nèi)パ芯恳幌?,這里的文章只考慮 MyISAM 和InnoDB這兩個,因為這兩個是最常見的
    2013-06-06
  • 淺談Mysql8和mysql5.7的區(qū)別

    淺談Mysql8和mysql5.7的區(qū)別

    本文主要介紹了Mysql8和mysql5.7的區(qū)別,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • MySQL8.0數(shù)據(jù)庫開窗函數(shù)圖文詳解

    MySQL8.0數(shù)據(jù)庫開窗函數(shù)圖文詳解

    開窗函數(shù)為將要被操作的行的集合定義一個窗口,它對一組值進行操作,不需要使用GROUP BY子句對數(shù)據(jù)進行分組,能夠在同一行中同時返回基礎行的列和聚合列,這篇文章主要給大家介紹了關于MySQL8.0數(shù)據(jù)庫開窗函數(shù)的相關資料,需要的朋友可以參考下
    2023-06-06
  • 詳解MySQL8.0 密碼過期策略

    詳解MySQL8.0 密碼過期策略

    這篇文章主要介紹了MySQL8.0 密碼過期策略的相關資料,幫助大家更好的理解和使用MySQL8.0的新功能,感興趣的朋友可以了解下
    2020-11-11
  • MySQL在grant時報錯ERROR?1064?(42000)的原因及解決方法

    MySQL在grant時報錯ERROR?1064?(42000)的原因及解決方法

    網(wǎng)上查到的grant方式大多會報錯,主要原因是MySQL版本8.0后不能再使用原來的方式,這篇文章主要介紹了MySQL在grant時報錯ERROR?1064?(42000),需要的朋友可以參考下
    2022-08-08
  • MySQL 數(shù)據(jù)類型詳情

    MySQL 數(shù)據(jù)類型詳情

    這篇文章主要介紹了MySQL 數(shù)據(jù)類型,數(shù)值類型分類又分嚴格數(shù)值類型和近似數(shù)值數(shù)據(jù)類型,下面文章圍繞MySQL 數(shù)據(jù)類型展開內(nèi)容,需要的朋友可以參考一下
    2021-11-11
  • 解決mysql登錄錯誤:''Access denied for user ''root''@''localhost''

    解決mysql登錄錯誤:''Access denied for user ''root''@''localhost''

    這篇文章主要介紹了mysql登錄錯誤:'Access denied for user 'root'@'localhost',本文給出了操作過程及注意事項,需要的朋友可以參考下
    2019-11-11
  • php中關于mysqli和mysql區(qū)別的一些知識點分析

    php中關于mysqli和mysql區(qū)別的一些知識點分析

    看書、看視頻的時候一直沒有搞懂mysqli和mysql到底有什么區(qū)別。于是今晚“谷歌”一番,整理一下。需要的朋友可以參考下。
    2011-08-08
  • mysql查詢的控制語句圖文詳解

    mysql查詢的控制語句圖文詳解

    這篇文章主要給大家介紹了關于mysql查詢控制語句的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04

最新評論