Когда GORM transactions лучше не использовать или использовать осторожно?
Что хотят услышать интервьюеры:
Суть: GORM поддерживает транзакции через db.Transaction или Begin/Commit.
Ответ:
Пример:
db.Transaction(func(tx *gorm.DB) error { return tx.Create(&u).Error }) Практический акцент: Оцените trade-off: простота, производительность, тестируемость, связность пакетов и цена поддержки.
Типичная ошибка: смешивать tx и обычный db внутри одной транзакционной операции.
Как отвечать на собеседовании: На интервью лучше показать, что вы выбираете инструмент под задачу: raw SQL, sqlc, GORM, pgx или sqlx — у каждого свой trade-off.