Re: Howto change column length

Поиск
Список
Период
Сортировка
От Stephan Szabo
Тема Re: Howto change column length
Дата
Msg-id 20011106092707.E44948-100000@megazone23.bigpanda.com
обсуждение исходный текст
Ответ на Re: Howto change column length  (bpalmer <bpalmer@crimelabs.net>)
Список 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 по дате отправления:

Предыдущее
От: Stephan Szabo
Дата:
Сообщение: Re: self outer join
Следующее
От: Jeff Eckermann
Дата:
Сообщение: Re: postgres 7.1.1 on Freebsd 4.3?