Re: full vacuum of a very large table

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



--- On Tue, 3/29/11, Nic Chidu <nic@xxxxxxxxx> wrote:

> From: Nic Chidu <nic@xxxxxxxxx>
> Subject:  full vacuum of a very large table
> To: pgsql-admin@xxxxxxxxxxxxxx
> Date: Tuesday, March 29, 2011, 11:56 AM
> Got a situation where a 130 mil rows
> (137GB) table needs to be brought down in size to  10
> mil records (most recent)
> with the least amount of downtime. 
> 
> Doing a full vacuum would be faster on:
>  - 120 mil rows deleted and 10 mil active (delete most of
> them then full vacuum)
>  - 10 mil deleted and 120 mil active. (delete small batches
> and full vacuum after each delete). 
> 
> Any other suggestions?
> 
> Thanks,
> 
> Nic
> 
> -- 

Nic,

Since you know the where clause to delete the 120 mil rows why not use the converse of that to select the 10 mil rows to retain into another table, then drop the original table?  No vacuum required!

Be sure to use the "create table as select..." syntax to avoid WAL during creation of the new table, and use a transaction to drop the original table and rename the new one.  That way users will be querying the original table right up until the switch over, when they will start using the new table.  

Foreign keys and other constraints may complicate things a bit, so check those out first.  Also, don't forget to index and analyze the new table before the switch over.

Good luck!

Bob Lunney




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



[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux