Как правильно применять database constraints в реальном Java/Spring проекте?
Что хотят услышать интервьюеры:
Практический подход: используйте database constraints там, где он решает конкретную задачу, а не ради моды.
- Определите слой: domain, application, infrastructure или API.
- Проверьте влияние на транзакции, потокобезопасность, тесты и поддержку.
- Зафиксируйте контракт через тест или явно описанный API.
Ответ:
На собеседовании: сильный ответ показывает trade-off и production-последствия. Риск: полагаться только на проверку в Java-коде.
ALTER TABLE users ADD CONSTRAINT uq_email UNIQUE(email);