sql_modeは悪魔の設定

2017/03/26

DB mysql

t f B! P L

なぜそのSQL文がエラーにならないのか?

久しぶりにMySQLを使ったシステムのお仕事。INSERT文でnot null制約の付いたカラムが書かれていないのに、エラーにならずに実行されていて???となったが、これ、sql_modeに STRICT_ALL_TABLES も STRICT_TRANS_TABLES もセットされていないからだった。

STRICT_ALL_TABLES と STRICT_TRANS_TABLES

MySQL :: MySQL 5.6 リファレンスマニュアル :: 5.1.7 サーバー SQL モードの「厳密な SQL モード」にSTRICT_ALL_TABLES と STRICT_TRANS_TABLES の説明がある。厳密モードが有効でない場合、MySQL は無効または欠落した値に対して調整された値を挿入し、警告を生成します とあり、not null制約のカラムに値がセットされない場合は「調整された値を挿入」して辻褄を合わせてくれる。まさに、「小さな親切大きなお世話」な仕様だ。

デフォルト設定はどうなっているのか?

5.6, 5.7ではSTRICT_TRANS_TABLESがセットされる。
5.5以前にはSTRICT_TRANS_TABLESはない

5.6になってまともになったようだ。

AWS RDS MySQL 5.6にはSTRICT_TRANS_TABLESはない

ちゃんと設定しましょう。

今の設定はどうなっている?

my.cnfを確認。なのだが、

  • MySQLのサーバはインフラチームが管理していて、ログインできない
  • RDS MySQLなのでmy.cnfを見れない
といったケースもある。何のことはない。mysqlなどクライアントプログラムから繋いで
SELECT @@GLOBAL.sql_mode;
とすればOK。

sql_modeを変更するときの影響範囲は?

sql_modeはmy.cnfで設定する。ので、Server全体に影響する。だが、session単位(接続単位)で変更することができる。

SET SESSION sql_mode='設定したいmode';
複数のmodeを設定する場合も
SET SESSION sql_mode='STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION';
とすればよい。
いちいち書くのが面倒?当然Connectionを管理するライブラリ使っているでしょうから、そのライブラリをよーく調べてみましょう。SpringFrameworkなら、AOPでさっくりと。


楽天で探す
楽天市場
にほんブログ村 IT技術ブログへ

人気の投稿

ブログ アーカイブ

自己紹介

開発からSREにクラスチェンジしました。

アフィリエイト

  • 当ブログ「Hiroaki's blog」は、amazon.co.jpを宣伝しリンクすることによってサイトが紹介料を獲得できる手段を提供することを目的に設定されたアフィリエイト宣伝プログラムである、Amazonアソシエイト・プログラムの参加者です。
  • 当ブログでは、第三者配信による広告サービスを利用しています。このような広告配信事業者は、ユーザーの興味に応じた商品やサービスの広告を表示するため、当サイトや他サイトへのアクセスに関する情報 (氏名、住所、メール アドレス、電話番号は含まれません) を使用することがあります。このプロセスの詳細やこのような情報が広告配信事業者に使用されないようにする方法については、ここをクリックしてください。
  • アクセストレードアフィリエイトプログラムに参加しています。
  • A8.netアフィリエイトプログラムに参加しています。
  • バリューコマースアフィリエイトプログラムに参加しています。
  • もしもアフィリエイトプログラムに参加しています。

プライバシーポリシー

当サイトにアクセスされる場合、IPアドレスなどの情報または閲覧状況に関するデータが機械的に生成され、場合によっては個人情報と関連付けられる可能性があります。プライバシー保護に関する適用法に準じて、これらの通信および閲覧に関するデータを収集、処理、および利用することがあります。
当サイトにアクセスされる場合、非個人情報(ブラウザの種類、OSの種類、ドメイン名、訪問数、平均滞在時間、ページ・ビューなど個人を特定できない情報)が自動収集される場合があります。当サイトのパフォーマンスやコンテンツを改善する目的で、これらの情報を利用する場合があります。
アフィリエイトでは成果を把握するためにcookie等を利用しています。それ以外の目的で使用されることはありません。詳しくは各社のページにて確認してください。
本サイトに掲載する情報に関しては、正しいものを提供することを務めていますが、掲載内容から、いかなる損失や損害などの被害が発生しても、当ブログでは責任を追いかねます。

QooQ