Чем database constraints отличается от only app validation и когда что выбрать?
Что хотят услышать интервьюеры:
Сравнение: database constraints стоит сравнивать с only app validation по критериям читаемости, безопасности, производительности, тестируемости и поддержки командой.
Ответ:
Когда выбирать database constraints: когда его свойства прямо соответствуют задаче: constraints защищают инварианты на уровне БД.
Слабый ответ: “так принято в Spring/Java”. На собеседовании лучше объяснить ограничения и цену выбора.
ALTER TABLE users ADD CONSTRAINT uq_email UNIQUE(email);