Re: Howto change column length - Mailing list pgsql-general

From Stephan Szabo
Subject Re: Howto change column length
Date
Msg-id 20011106092707.E44948-100000@megazone23.bigpanda.com
Whole thread Raw
In response to Re: Howto change column length  (bpalmer <bpalmer@crimelabs.net>)
List pgsql-general
On Tue, 6 Nov 2001, bpalmer wrote:

> > I have a column (ie name varchar(10))
> > and I want to alter it to varchar(20)
> > I've looked throught the docementation and web for examples (no luck),
> > can anyone help?
>
> That can't be done.  Once the datatype has been set,  it can't be changed
> (how would changing it from 20 to 10 work?  how about from varchar to int,
> etc).  With the limitation of not being able to drop a column yet,  you
> would need to create the new table and copy all the data from one to the

If you're willing to do a little magic to the system tables (and you have
a recent backup :) ).  You can change the atttypmod of the column in
question from 14 to 24.  This really only works on variable length items
and only to expand them, but...

You pretty much need to do a sequence like:
select oid, relname from pg_class where relname='<tablename>';
update pg_attribute set atttypmod=24 where attrelid=<oid from previous>
 and attname='<attributename>'
in a superuser account.




pgsql-general by date:

Previous
From: Stephan Szabo
Date:
Subject: Re: self outer join
Next
From: Jeff Eckermann
Date:
Subject: Re: postgres 7.1.1 on Freebsd 4.3?