データが入っているテーブルにDEFAULT付きのカラム追加SQL

SQL

データが入っているテーブルにDEFAULT付きのカラム追加 [SQL]

メンテナンス対応で、すでに大量のデータが入っているテーブルに対してカラム追加を行う必要があると思います。

データ量が多いテーブルに対して、DEFAULT値を設定したALTER TABLEを実行すると、全件にデフォルト値が登録されるため、処理時間に不安があると思います。
<pre class="EnlighterJSRAW" data-enlighter-language="sql">ALTER TABLE common_table ADD impact_flg char(1) DEFAULT '0';</pre>
この際、内部処理の実行順番は、大体のDBでALTER TABLEの後、DEFAULTを設定するUPDATEが実行されます。件数が多い場合、処理時間はハードウェアの性能によって決まります。

メンテなど計画停止をしてALTER TABLEする必要があり、事前に同程度の環境で実行計画と時間の測定をしておく必要はありますが、1億単位のレコードがあっても1時間はかからないケースがほとんどです。1時間以上かかる場合は途中で何らかの障害が起きている可能性があるため中断して再更新してみた方がいいかもしれません。

  • この記事を書いた人

朝倉卍丸

シングルモルトスコッチなどのお土産を持ってきた人を助けるのが好きです。サービスの分割が重要ですが、まあ昔ながらの方法でやりたいこともありますよね。

よく読まれている記事

条件の0=0は全てが正であるを意味するSQL 1

SQLの条件に0=0のような記述を見かけます。 変わった書き方の条件ですが、これは「全てが正である」事を意味しており、結合条件の場合はCROSS JOINと同じです。 下記の例で言えば、結合するsub ...

DISTINCTを使わないで重複排除を考えるSQL 2

SQLのDISTINCTはEXISTSとかGROUP BYでなんとかする事もできます。 DISTINCTは暗黙的なソートがされますが、何のDBを使うにせよ過去のバージョンならともかく、最近のバージョン ...

RFC 5322に準拠させた正規表現言語別 3

RFC5322で定義されている正規表現を、各言語の正規表現に変化させた形になります。 完全な電子メール正規表現は存在しないので、結局のところ何かの公式基準に従っていたとしても、自分が携わるサービスのル ...

-SQL