PostgreSQL:カラムの列追加でデフォルト値を設定

8系列では一発で列追加出来るのだけど、7系列では若干回りくどい。

PostgreSQL 8.* 以降

ALTER TABLE tab ADD COLUMN new_col integer DEFAULT 0 NOT NULL;

PostgreSQL 7.*系列

ALTER TABLE tab ADD COLUMN new_col integer;
ALTER TABLE tab ALTER COLUMN new_col SET DEFAULT 0;
UPDATE tab SET new_col=0; -- 既存レコードは NULL なので NOT NULL の前にデフォルト値を設定
ALTER TABLE tab ALTER COLUMN new_col SET NOT NULL;
Tagged with:
Posted in database

Leave a Reply

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out / Change )

Twitter picture

You are commenting using your Twitter account. Log Out / Change )

Facebook photo

You are commenting using your Facebook account. Log Out / Change )

Google+ photo

You are commenting using your Google+ account. Log Out / Change )

Connecting to %s

Archives
  • RT @__apf__: How to write a research paper: a guide for software engineers & practitioners. docs.google.com/presentation/d… /cc @inwyrd 6 days ago
  • RT @HayatoChiba: 昔、自然と対話しながら数学に打ち込んだら何かを悟れるのではと思いたち、専門書1つだけ持ってパワースポットで名高い奈良の山奥に1週間籠ったことがある。しかし泊まった民宿にドカベンが全巻揃っていたため、水島新司と対話しただけで1週間過ぎた。 それ… 3 weeks ago
  • RT @googlecloud: Ever wonder what underwater fiber optic internet cables look like? Look no further than this deep dive w/ @NatAndLo: https… 3 weeks ago
  • @ijin UTC+01:00 な時間帯で生活しています、、、 6 months ago
  • RT @mattcutts: Google's world-class Site Reliability Engineering team wrote a new book: amazon.com/Site-Reliabili… It's about managing produc… 9 months ago
%d bloggers like this: