Re: Partitioning an existing table

Поиск
Список
Период
Сортировка
От Vick Khera
Тема Re: Partitioning an existing table
Дата
Msg-id BANLkTinFZk7RgsG111s_teM50EoF7cq93Q@mail.gmail.com
обсуждение исходный текст
Ответ на Partitioning an existing table  (Phoenix Kiula <phoenix.kiula@gmail.com>)
Ответы Re: Partitioning an existing table  (Raghavendra <raghavendra.rao@enterprisedb.com>)
Re: Partitioning an existing table  (Greg Smith <greg@2ndQuadrant.com>)
Список pgsql-general
On Mon, Apr 25, 2011 at 6:46 AM, Phoenix Kiula <phoenix.kiula@gmail.com> wrote:
I could create a new parent table with child tables, and then INSERT
all these millions of rows to put them into the right partition. But
is that recommended?

I did this twice (several years ago).  Basically, you create your partitions and set up the necessary triggers you want (I re-write the app to insert directly into the correct partition).  Then all new data starts going into the partitions.  Next, write a program that loops over the current master table, and moves the data into each partition some small hunk at a time, in a transaction.  This can take a long time.  For us, it took about 7 days to move O(100m) rows.  Then, when you're done, truncate the master table, and enforce that no new data is allowed to be inserted into it.

If you can, of course, try this out on a spare copy of that table.

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

Предыдущее
От: Phoenix Kiula
Дата:
Сообщение: Re: Help - corruption issue?
Следующее
От: Adrian Klaver
Дата:
Сообщение: Re: pipe line error (psql command)