Simple delete takes hours

From: Thomas Mueller <news-exp-jul05(at)tmueller(dot)com>
To: pgsql-sql(at)postgresql(dot)org
Subject: Simple delete takes hours
Date: 2005-03-03 21:44:58
Message-ID: d0807h$vuu$1@sea.gmane.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

Hi there,

I have a simple database:

CREATE TABLE pwd_description (
id SERIAL NOT NULL UNIQUE PRIMARY KEY,
name varchar(50) NOT NULL
);

CREATE TABLE pwd_name (
id SERIAL NOT NULL UNIQUE PRIMARY KEY,
description integer NOT NULL REFERENCES pwd_description(id),
name varchar(50) NOT NULL,
added timestamp DEFAULT now()
);

CREATE TABLE pwd_name_rev (
id SERIAL NOT NULL UNIQUE PRIMARY KEY,
description integer NOT NULL REFERENCES pwd_description(id),
rev_of integer NOT NULL REFERENCES pwd_name(id) ON DELETE
CASCADE,
name varchar(50) NOT NULL
);

The indexes shouldn't matter I think.

pwd_name_rev is filled by a stored procedure and a trigger (ON INSERT)
when something is inserted to pwd_name. Both tables contain about
4.500.000 emtries each.

I stopped 'delete from pwd_name where description=1' after about 8 hours
(!). The query should delete about 500.000 records.
Then I tried 'delete from pwd_name_rev where description=1' - this took
23 seconds (!).
Then I retried the delete on pwd_name but it's running for 6 hours now.

I use PostgreSQL 7.4.7 on Linux 2.6.10. The machine is a Celeron 2 GHz
with 512 MB RAM.

PostgreSQL should do a full table scan I think, get all records with
description=1 and remove them - I don't understand what's happening for
>8 hours.

Any help is appreciated.

Thomas

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Bret Hughes 2005-03-04 05:47:10 Re: definative way to place secs from epoc into timestamp
Previous Message Andrew - Supernews 2005-03-03 20:58:14 Re: definative way to place secs from epoc into timestamp