Какой реальный баг может возникнуть из-за неправильного понимания UPSERT?

GoMiddleDatabases and PostgreSQLТеорияdatabases_and_postgresqlupsertgo_backend_developer

Что хотят услышать интервьюеры:

Суть: UPSERT вставляет или обновляет запись при конфликте.

Ответ:

Пример:

INSERT ... ON CONFLICT(id) DO UPDATE

Практический акцент: Проверяйте не только happy path: добавьте негативные сценарии, timeout/cancel, граничные значения и регрессионный тест на типичную ошибку.

Типичная ошибка: делать read-then-insert и ловить race condition.

Как отвечать на собеседовании: Связывайте Go-код с SQL-планом, pool, транзакциями и контекстом запроса. Это частая проверка Middle/Senior Go.

Источники

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