Re: keeping last 30 entries of a log table - Mailing list pgsql-sql

From Daniel CAUNE
Subject Re: keeping last 30 entries of a log table
Date
Msg-id 0J1400MJFAIHSME0@VL-MH-MR002.ip.videotron.ca
Whole thread Raw
In response to Re: keeping last 30 entries of a log table  (Jeff Frost <jeff@frostconsultingllc.com>)
Responses Re: keeping last 30 entries of a log table
List pgsql-sql
> >> insert into log (account_id, message) values (1, 'this is a test);
> >> delete from log where account_id = 1 and id not in ( select id from log
> >>    where account_id = 1 order by timestamp desc limit 30);
> >>
> >> I'm wondering if there is a more performance oriented method of doing
> the
> >> delete that I'm not thinking of.
> >>
> >
> > Depending on whether id is a kind of auto-incremented column that never
> cycles, I would suggest something like:
> >
> > DELETE FROM log
> >  WHERE account_id = 1
> >    AND id < (
> >      SELECT MIN(id)
> >        FROM log
> >        WHERE account_id = 1
> >        ORDER BY timestamp DESC
> >        LIMIT 30);
> >
> > I think there will be a performance difference with your method when the
> number of records to be deleted is huge.
> 
> Thanks Daniel, I'll try and benchmark them both and see if < turns out to
> be
> faster than NOT IN.  I guess there's no way to get around the subselect
> though.
> 

Column id should be indexed indeed.  Anyway, I'm not sure about any performance improvement using that last method, as
themost consuming operation might be the DELETE operation, not really the SELECT operation, when dealing with a huge
volumeof data.
 


--
Daniel



pgsql-sql by date:

Previous
From: Jeff Frost
Date:
Subject: Re: keeping last 30 entries of a log table
Next
From: "Dirk Jagdmann"
Date:
Subject: Re: keeping last 30 entries of a log table