172 похожих чатов

Цель: либо вставить строку, либо при конфликте вернуть то, что

помешало вставить.

Делаю так:

WITH ins AS (
INSERT INTO storage (key, value)
VALUES ($1, $2)
ON CONFLICT (key) DO NOTHING
RETURNING key, value
)
(SELECT key, value FROM ins)
UNION ALL
(SELECT key, value FROM storage WHERE key = $1)
LIMIT 1


Вопрос: сработает ли это при одновременной вставке, когда строки с ключем еще нет? Мне кажется, да.

Рассуждаю так: второй параллельный INSERT залочится ожидая завершения первой транзакции, после чего случится ON CONFLICT DO NOTHING и оно перейдет во вторую часть UNION ALL где из-за READ COMMITTED изоляции уже должна быть видна только что вставленная строка.

Я прав?

1 ответов

3 просмотра
Mike-Wazowski Автор вопроса

Немного разверну мысль. В целом каждый statement в транзакции видит свой снапшот. При Read Comitted разные statement могут увидеть разное состояние базы. Но вот может ли поменяться снэпшот внутри одного выражения? Цитата из доки: > It is very difficult to enforce business rules regarding data integrity using Read Committed transactions because the view of the data is shifting with each statement, and even a single statement may not restrict itself to the statement's snapshot if a write conflict occurs. т.е. если был write conflict , то вроде как может, а значит должно сработать.

Похожие вопросы

Обсуждают сегодня

я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
в сях есть множество как в питоне? для удаление дубликатов
.
25
читать файл максимально быстро? странный вопрос))
zamtmn
53
How to create an OS in C? what to study?
.
18
тоесть, указав return eax, сгенерируется никому ненужная инструкция mov eax,eax ?
Aiwan \ (•◡•) / _bot
24
Всем доброго вечера! Хочу поделиться своим злоключением с человеком, который, как оказалось сюда тоже скидывал свое резюме. Жаль, что я вашу группу не нашел раньше… человек ки...
Роман Ахмедзянов
4
Компания Elif ищет менеджера проектов, который будет заниматься поиском и ведением новых проектов. Прежде чем приступить к работе, вам нужно пройти наш недельный курс, где вы ...
Elif
5
Привет, кто может сделать юзербота с апи? Задачи: - создавать группы - создавать каналы - задавать для созданных каналов аватарку или эмоджи, имя группы - добавлять в группы...
Lencore
11
а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Кто может подсказать? Я преобрпзовал изображение в бинарное(у меня установлен трекбар который при установленном значении меняет пиксели на белый если меньше и чёрный если боль...
Константин VS
6
Карта сайта