Re: Converting char to varchar automatically

Поиск
Список
Период
Сортировка
От Melvin Davidson
Тема Re: Converting char to varchar automatically
Дата
Msg-id CANu8FizacQHwG43KdtKumsLBO1cOJi-u01ZddKf-YLW+68_C2A@mail.gmail.com
обсуждение исходный текст
Ответ на Re: Converting char to varchar automatically  (Jim Nasby <Jim.Nasby@BlueTreble.com>)
Ответы Re: Converting char to varchar automatically  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-general
Also, don't forget to test for relkind = 'r'. My bad from before.
Revised query is below.

SELECT 'ALTER TABLE ' || quote_ident(n.nspname) || '.'
             || quote_ident(c.relname)
             || ' ALTER COLUMN ' || quote_ident(a.attname) || ' TYPE varchar;'
   FROM pg_class c
     JOIN pg_namespace n ON n.oid = c.relnamespace
     JOIN pg_attribute a ON a.attrelid = c.oid
     JOIN pg_type t ON t.oid = a.atttypid
WHERE t.typname = 'bpchar'
    AND c.relkind = 'r'
    AND n.nspname <> 'pg_catalog';

On Mon, Oct 6, 2014 at 6:18 PM, Jim Nasby <Jim.Nasby@bluetreble.com> wrote:
On 10/6/14, 12:41 PM, hari.fuchs@gmail.com wrote:
Melvin Davidson <melvin6925@gmail.com> writes:

This query might work for you, but double check all result statements first.

SELECT 'ALTER TABLE ' || quote_ident(n.nspname) || '.' ||
quote_ident(c.relname)
        || ' ALTER COLUMN ' || quote_ident(a.attname) || ' TYPE varchar;'
   FROM pg_class c
   JOIN pg_namespace n ON n.oid = c.relnamespace
   JOIN pg_attribute a ON a.attrelid = c.oid
   JOIN pg_type t ON t.oid = a.atttypid
  WHERE t.typname = 'char'
    AND n.nspname <> 'pg_catalog';
Make that "t.typname = 'bpchar'".

Just a heads-up: each of those ALTER's will rewrite the table, so unless your database is tiny this will be a slow process. There's ways to work around that, but they're significantly more complicated.

--
Jim Nasby, Data Architect, Blue Treble
Data in Trouble? Get it in Treble! http://BlueTreble.com



--
Sent via pgsql-general mailing list (pgsql-general@postgresql.org)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-general



--
Melvin Davidson
I reserve the right to fantasize.  Whether or not you
wish to share my fantasy is entirely up to you.

В списке pgsql-general по дате отправления:

Предыдущее
От: Jim Nasby
Дата:
Сообщение: Re: How to get good performance for very large lists/sets?
Следующее
От: Jonathan Vanasco
Дата:
Сообщение: Re: faster way to calculate top "tags" for a "resource" based on a column