勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

MySQLで「doesn't have a default value」エラーの対処

  MySQL データベース

MySQLでINSERT時に「Field 'カラム名' doesn't have a default value」というエラーが発生した。ちなみに当該カラムはdatetime形式でINSERT時は何も値を入れない(UPDATE時に入れる予定)という状況。さらに本件は複数のサーバで作業中、3台中2台は正常に動作し、残りの1台でのみ発生していた。以下に原因と対応方法をメモ。

 

原因

MySQLモードの「STRICT_TRANS_TABLES」というのにひっかかったっぽい。

また、使用していたサーバはいずれも同じ会社のものと聞いていたため、各種バージョンも同じかと思いきやそれは勘違いで新しいバージョンのものでエラーが発生していた。

 

対象方法

INSERT時に正常な値を入れる

now()等で正常な値を入れるのが正攻法っぽい。ただ、今回は複数のサーバで同じプログラムを動かしたいというケースだったので差分は作りたくなかったため、次の方法を取った。

MySQLモードを変更する

以下でMySQLモードを変更した。恐らく非推奨。

SET GLOBAL sql_mode = '';

 

参考サイト

https://www.wakuwakubank.com/posts/414-mysql-sqlmode/

https://qiita.com/dogyear/items/75bb3d4deea1daf708c2

 - MySQL データベース

  関連記事

MySQLで経度緯度から半径○Kmのデータを抽出する方法

経度と緯度をtext型として格納しているMySQLのテーブルがあり、指定した経度 ...

MySQLにてSELECT時にdate型のカラムから和暦を計算し表示する方法

MySQLにdate型のカラムに誕生年月日が格納されており、そこから和暦を計算し ...

phpMyAdminでのエクスポート/インポート

DBのバックアップを取る際にエクスポート/インポートを行うが、 データ件数が多い ...

MySQLでスレッドの実行状況を表示しスレッドの経過時間チェックや特定スレッドを強制終了する方法

データベースサーバが重たく、原因を調査する機会があった。サーバ自体のメモリやCP ...

MySQLで全文検索(フルテキストインデックス)を使用する方法

普段利用しているサイトに検索用のテキストボックスがあり、そこに何らかのワードを入 ...