Re:Fwd: BUG #17017: Two versions of the same row of records are returned in one query - Mailing list pgsql-bugs

From 李可强
Subject Re:Fwd: BUG #17017: Two versions of the same row of records are returned in one query
Date
Msg-id tencent_53E42BE16C22D6872833143B@qq.com
Whole thread Raw
Responses Re: Fwd: BUG #17017: Two versions of the same row of records are returned in one query  (Peter Geoghegan <pg@bowt.ie>)
List pgsql-bugs
Hi Tom,
I think the repeatable read transaction should give priority to see the new version written by itself, e.g., the insertion of the above example. There is no need to return the old version written by committed transactions. The query result fo Session B is very confusing!

------------------ Original ------------------
Date:  Wed, May 19, 2021 09:05 AM
To:  "52194501011"<52194501011@stu.ecnu.edu.cn>;
Subject:  Fwd: BUG #17017: Two versions of the same row of records are returned in one query
 


---------- Forwarded message ---------
发件人: Tom Lane <tgl@sss.pgh.pa.us>
Date: 2021年5月19日周三 00:18
Subject: Re: BUG #17017: Two versions of the same row of records are returned in one query
To: <lpy.henu@gmail.com>
Cc: <pgsql-bugs@lists.postgresql.org>


PG Bug reporting form <noreply@postgresql.org> writes:
> Schema and Initial data:
> Create Table t(a int primary key, b int);
> Insert into t values(1,2);
> Insert into t values(2,3);

> [Time0, SessonA]
>> Begin;
>> set transaction isolation level repeatable read;
>> Select * from t where a=1;

> [Time1, SessonB]
>> Begin;
>> set transaction isolation level read committed;
>> Delete from t where a=2;
>> Commit;

> [Time2, SessonA]
>> Insert into t values(2,4);
>> Select * from t where a=2;

> Here, we expect PostgreSQL Server to return a row:
> 2 3

> However, it returns two rows:
> 2 4
> 2 3

In repeatable read mode, this doesn't surprise me.  Session A
surely must return the (2,3) row, since it isn't supposed to
"see" the results of Session B's commit yet.  And it would be
mighty surprising for it not to see its own insertion, so you
get (2,4) as well.

In serializable mode, I'd expect this situation to throw a
serialization error, and it does (but you must run BOTH
transactions in serializable mode; there are not guarantees
with a mix of serializable and non-serializable transactions).

So I think the answer is "if you care about this, use
serializable mode".  Repeatable read mode meets the
requirements of the SQL spec, but it doesn't guarantee
no anomalies.

                        regards, tom lane

pgsql-bugs by date:

Previous
From: David Rowley
Date:
Subject: Re: Query with straightforward plan changes and becomes 6520 times slower after VACUUM ANALYZE
Next
From: PG Bug reporting form
Date:
Subject: BUG #17022: SQL causing engine crash