Чем транзакция не откатывается отличается от плохой SQL и когда что выбрать?
Что хотят услышать интервьюеры:
Сравнение: транзакция не откатывается стоит сравнивать с плохой SQL по критериям читаемости, безопасности, производительности, тестируемости и поддержки командой.
Ответ:
Когда выбирать транзакция не откатывается: когда его свойства прямо соответствуют задаче: проверяют тип exception, proxy invocation, propagation и границу @Transactional.
Слабый ответ: “так принято в Spring/Java”. На собеседовании лучше объяснить ограничения и цену выбора.
// checked exception? self-invocation? proxy?