Когда UPSERT лучше не использовать или использовать осторожно?

GoMiddle+Databases and PostgreSQLТеорияdatabases_and_postgresqlupsertgo_backend_developer

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

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

Ответ:

Пример:

INSERT ... ON CONFLICT(id) DO UPDATE

Практический акцент: Оцените trade-off: простота, производительность, тестируемость, связность пакетов и цена поддержки.

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

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

Источники

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