Re: Atomar SQL Statement

From: Stephan Szabo <sszabo(at)megazone(dot)bigpanda(dot)com>
To: Michael Glaesemann <grzm(at)seespotcode(dot)net>
Cc: "Weber, Johann (ISS Kassel)" <jweber(at)iss(dot)net>, pgsql-sql(at)postgresql(dot)org
Subject: Re: Atomar SQL Statement
Date: 2006-07-07 18:07:10
Message-ID: 20060707105847.J77811@megazone.bigpanda.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql


On Fri, 7 Jul 2006, Michael Glaesemann wrote:

>
> On Jul 7, 2006, at 7:55 , Weber, Johann (ISS Kassel) wrote:
>
> > My concern: in a multi threaded environment, can a second thread
> > interrupt this statement and eventually insert the same email
> > address in
> > the table with a different id? Or is this statement atomar?
>
> You're safe. Take a look at the FAQ entries on SERIAL:
>
> http://www.postgresql.org/docs/faqs.FAQ.html#item4.11.2

I don't think he is, because I don't think the issue is the SERIAL
behavior, but instead the NOT EXISTS behavior. Won't the NOT EXISTS in
read committed potentially be true for both concurrent sessions if the
second happens before the first commits, which then would mean that both
sessions will go on to attempt the insert (with their own respective ids
from the serial)? Without a unique constraint on email I think he can end
up with the same email address with two different ids.

In response to

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Rodrigo De Leon 2006-07-07 18:37:08 Re: SELECT substring with regex
Previous Message Forums @ Existanze 2006-07-07 17:56:56 Custom Data Type Mapping JDBC