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

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

DDD
發布: 2024-12-02 11:48:10
原創
955 人瀏覽過

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中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板