首頁 >資料庫 >mysql教程 >為什麼在 MySQL 中新增列會導致「'created_at'的預設值無效」錯誤?

為什麼在 MySQL 中新增列會導致「'created_at'的預設值無效」錯誤?

DDD
DDD原創
2024-12-02 11:48:10897瀏覽

Why Does Adding a Column Result in an

Created_At的預設值無效

問題:

嘗試透過以下方式變更表格時新增欄位時,您會遇到錯誤:

ERROR 1067 (42000): Invalid default value for 'created_at'

儘管沒有修改任何時間戳列。

解:

錯誤源自sql_modes。要解決這個問題:

  1. 檢查SQL 模式:
show variables like 'sql_mode' ;
  1. 停用有問題的模式:
停用有問題的模式:

NO_ZERO_IN_DATE
NO_ZERO_DATE

從下列模式中刪除sql_mode:

這些模式預設存在於較新的 MySQL 版本中。

全域設定:

set global sql_mode = 'ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

對於系統範圍的更改,以root 身分執行以下命令:

    其他注意:
  • 現在可以新增欄位而不會觸發錯誤。
ALTER TABLE investments ADD bank TEXT DEFAULT NOT NULL;
如果您希望為created_at使用預設的NOT NULL值,您可以明確指定它:

以上是為什麼在 MySQL 中新增列會導致「'created_at'的預設值無效」錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn