Re: BUG #17301: SELECT gets weird result while two transactions are submitted concurrently
От | Tom Lane |
---|---|
Тема | Re: BUG #17301: SELECT gets weird result while two transactions are submitted concurrently |
Дата | |
Msg-id | 708274.1638118266@sss.pgh.pa.us обсуждение исходный текст |
Ответ на | BUG #17301: SELECT gets weird result while two transactions are submitted concurrently (PG Bug reporting form <noreply@postgresql.org>) |
Список | pgsql-bugs |
PG Bug reporting form <noreply@postgresql.org> writes: > /* init */ create table t(a int primary key, b int); > /* init */ insert into t values (1, 2), (2, 3) > /* t1 */ begin; > /* t1 */ set transaction isolation level repeatable read; > /* t1 */ select * from t where a = 1; > /* t2 */ begin; > /* t2 */ set transaction isolation level repeatable read; > /* t2 */ delete from t where a = 2; > /* t2 */ commit; > /* t1 */ update t set a = 2 where a = 1; > /* t1 */ select * from t where a = 2; -- [(2, 3), (2, 2)] > /* t1 */ commit; > The final SELECT statement gets result [(2, 3), (2, 2)], which violates the > primary key constraint on column `a`. This is operating as designed. There are only three plausible behaviors in this situation: 1. Fail t1's last SELECT (or, perhaps, its UPDATE). You'll get that if you use SERIALIZABLE mode. 2. In t1's last SELECT, don't show the committed-dead (2,3) row. This violates the premise of REPEATABLE READ: t1 could see that row at the start of its run, and it hasn't modified it, so it should still see it. 3. In t1's last SELECT, show both rows. We choose #3. If you want #2, you should be using READ COMMITTED mode, while if you want #1, you should be using SERIALIZABLE. regards, tom lane
В списке pgsql-bugs по дате отправления: