Re: time taking deletion on large tables

From: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
To: Justin Pryzby <pryzby(at)telsasoft(dot)com>
Cc: Ravikumar Reddy <urravikumarreddy(at)gmail(dot)com>, Atul Kumar <akumar14871(at)gmail(dot)com>, pgsql-performance <pgsql-performance(at)lists(dot)postgresql(dot)org>
Subject: Re: time taking deletion on large tables
Date: 2020-12-03 16:16:16
Message-ID: 1735185.1607012176@sss.pgh.pa.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-admin pgsql-docs pgsql-in-general pgsql-performance

Justin Pryzby <pryzby(at)telsasoft(dot)com> writes:
> On Thu, Dec 03, 2020 at 08:43:57PM +0530, Ravikumar Reddy wrote:
>> When I try to do a delete like this: it hangs for an entire day, so I
>> need to kill it with pg_terminate_backend(pid).
>>
>> DELETE FROM feed_posts
>> WHERE feed_definition_id = 'bf33573d-936e-4e55-8607-72b685d2cbae'
>> AND created_at > '2020-05-11 00:00:00'
>> AND created_at < '2020-05-12 00:00:00';

90% of the "delete takes forever" complaints that we hear trace down to
having a foreign key reference to the deletion-target table that's not
backed by an index on the referencing column. Then you end up getting
a seqscan on the referencing table to look for rows referencing a
row-to-be-deleted. And then another one for the next row. Etc.

You could try "explain analyze" on a query deleting just a single
one of these rows and see if an RI enforcement trigger is what's
eating the time.

regards, tom lane

In response to

Responses

Browse pgsql-admin by date

  From Date Subject
Next Message Andrew Dunstan 2020-12-03 17:00:44 Re: time taking deletion on large tables
Previous Message Ron 2020-12-03 15:48:46 Re: time taking deletion on large tables

Browse pgsql-docs by date

  From Date Subject
Next Message Andrew Dunstan 2020-12-03 17:00:44 Re: time taking deletion on large tables
Previous Message Ron 2020-12-03 15:48:46 Re: time taking deletion on large tables

Browse pgsql-in-general by date

  From Date Subject
Next Message Andrew Dunstan 2020-12-03 17:00:44 Re: time taking deletion on large tables
Previous Message Ron 2020-12-03 15:48:46 Re: time taking deletion on large tables

Browse pgsql-performance by date

  From Date Subject
Next Message Andrew Dunstan 2020-12-03 17:00:44 Re: time taking deletion on large tables
Previous Message Ron 2020-12-03 15:48:46 Re: time taking deletion on large tables