Re: FIFO Queue Problems
| От | Tom Lane | 
|---|---|
| Тема | Re: FIFO Queue Problems | 
| Дата | |
| Msg-id | 26900.1036169461@sss.pgh.pa.us обсуждение исходный текст  | 
		
| Ответ на | FIFO Queue Problems (Chris Gamache <cgg007@yahoo.com>) | 
| Ответы | 
                	
            		Re: FIFO Queue Problems
            		
            		 | 
		
| Список | 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 по дате отправления: