Hello everybody,
I have just joined the list, as I am experiencing a degradation on
performances on my PostgreSQL instance, and I was looking for some
insights on how to fix/avoid it.
What I have observed are impossibly high time on delete statements on
some tables.
The delete statement is very simple:
delete from table where pk = ?
The explain query report a single index scan on the primary key index,
as expected.
I have run vacuum using the pgAdmin tool, but to no avail.
I have also dropped and recreated the indexes, again without any benefit.
I have later created a copy of the table using the "create table
table_copy as select * from table" syntax.
Matching the configuration of the original table also on the copy
(indexes and constraints), I was able to delete the raws from the new
table with regular performances, from 20 to 100 times faster than
deleting from the original table.
Given this evidence, what are the best practices to fix/avoid this
kind of problems?
I am using PostgreSQL 8.1.4 both on Linux (on a Parallels virtual
machine with a Linux OS) and on Solaris, on a hosted zone; the Solaris
version is running the live DB, while the Linux instance is on my
development machine using a snapshot of the live data.
Thanks for your attention.
Best regards,
Giulio Cesare Solaroli