テーブル変更時の無効なデフォルト値エラー
新しい列を追加してテーブルを変更しようとすると、エラーが発生しました: 「エラー」 1067 (42000): 'created_at' のデフォルト値が無効です。」グーグルで調べたにもかかわらず、このエラーは通常、タイムスタンプの変更中に発生することがわかりました。ただし、この状況では、「bank」という名前の新しいテキスト列を追加する必要があります。
この問題を解決するには、sql_modes を確認する必要があります。次のコマンドを使用します。
show variables like 'sql_mode' ;
sql_mode に「NO_ZERO_IN_DATE,NO_ZERO_DATE」が存在する場合、これが問題の原因です。クエリを成功させるには、これらのモードを無効にします。
root ユーザーとして sql_mode をグローバルに変更するには、次のコマンドを実行します。
set global sql_mode = 'ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
問題のある sql_mode を無効にしたら、投資テーブルに「銀行」列を正常に追加できるようになりました。
以上がテーブルにテキスト列を追加すると「無効なデフォルト値」エラーが発生するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。