Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Postgres: postgres, upsert, transaction

В каких случаях UPSERT (ON CONFLICT) в Postgres может быть опасен?

Проверяет знание SQL, конкуренции транзакций и побочных эффектов UPSERT.

Короткий ответ

UPSERT может скрывать логические ошибки, приводить к потерянным обновлениям и неожиданным блокировкам при высокой конкуренции.

Длинный ответ

INSERT ... ON CONFLICT DO UPDATE удобен, но опасен:

  • сложно отличить insert от update;

  • возможны race-condition при вычисляемых полях;

  • update может перезаписать данные, рассчитанные другой транзакцией;

  • при высокой конкуренции возрастает количество блокировок.

Типичный баг:

  • два запроса читают старое значение;

  • оба делают UPSERT;

  • последнее обновление затирает первое.

Для критичных данных лучше:

  • явные транзакции;

  • SELECT FOR UPDATE;

  • оптимистичная блокировка по версии.

Вывод: UPSERT — не серебряная пуля, особенно в финансовых и счётных системах.

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    4

  • Сложность:

    7

Навыки

  • Postgres

    Postgres

Ключевые слова

#postgres

#upsert

#transaction

Подпишись на Golang Developer в телеграм

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.