Какой реальный баг может возникнуть из-за неправильного понимания transactions?
Что хотят услышать интервьюеры:
Суть: transaction группирует операции в атомарный блок с commit/rollback.
Ответ:
Пример:
tx, err := db.BeginTx(ctx, nil) Практический акцент: Проверяйте не только happy path: добавьте негативные сценарии, timeout/cancel, граничные значения и регрессионный тест на типичную ошибку.
Типичная ошибка: делать внешние HTTP-вызовы внутри транзакции и держать locks слишком долго.
Как отвечать на собеседовании: Связывайте Go-код с SQL-планом, pool, транзакциями и контекстом запроса. Это частая проверка Middle/Senior Go.