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 по дате отправления: