Created_At的預設值無效
問題:
嘗試透過以下方式變更表格時新增欄位時,您會遇到錯誤:
ERROR 1067 (42000): Invalid default value for 'created_at'
儘管沒有修改任何時間戳列。
解:
錯誤源自sql_modes。要解決這個問題:
show variables like 'sql_mode' ;
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中文網其他相關文章!