Re: FIFO Queue Problems - Mailing list pgsql-sql

From Tom Lane
Subject Re: FIFO Queue Problems
Date
Msg-id 26900.1036169461@sss.pgh.pa.us
Whole thread Raw
In response to FIFO Queue Problems  (Chris Gamache <cgg007@yahoo.com>)
Responses Re: FIFO Queue Problems  (Wei Weng <wweng@kencast.com>)
List pgsql-sql
Chris Gamache <cgg007@yahoo.com> writes:
> I have a program that claims a row for itself

>   my $processid = $$;
>   my $sql_update = <<EOS;
>     UPDATE fifo
>       set status=$processid
>     WHERE id = (SELECT min(id) FROM fifo WHERE status=0);
> EOS

> The problem occurrs when two of the processes grab the exact same row at the
> exact same instant.

Probably the best fix is to do it this way:
BEGIN;LOCK TABLE fifo IN EXCLUSIVE MODE;UPDATE ... as above ...COMMIT;

The exclusive lock will ensure that only one process claims a row
at a time (while not preventing concurrent SELECTs from the table).
This way you don't need to worry about retrying.
        regards, tom lane


pgsql-sql by date:

Previous
From: Bruno Wolff III
Date:
Subject: Re: FIFO Queue Problems
Next
From: Reinoud van Leeuwen
Date:
Subject: Re: Database Design tool