Я разрабатываю одну ERP-систему для малых и средних организаций, застрял, когда приходит операция удаления для сущностей. Прямо сейчас у меня есть одна сущность Project и Task, т.е. у одного проекта много задач теперь у меня есть три варианта, пока выполняется операция удаления.
1> либо навсегда удалить данные из базы данных, с дочерними данными то есть, если проект удален, то также удалите связанные с ним задачи
, здесь проблема в том, что мы не сможем вернуться, как только он будет удален.
2> либо только установите для isDeleted значение true ,
здесь проблема в том, что если у какой-либо сущности isDeleted равно true, то связанная с ней сущность может получить ее с помощью метода Getter (так что это не очень хорошая идея) если в проекте P1 есть три задачи T1, T2, T3 с типом извлечения EAGER. Например, если я установил Задачу T1 как isDeleted в true, тогда, если я получу проект P1, он также получит три задачи вместе с T1, потому что между ними все еще существует связь, T1 обновляется только до isDeleted до true.
3> или сохранить все события (CRUD) объекта в отдельных таблицах истории
здесь проблема заключается в следующем: размер базы данных будет в несколько раз больше, чем в обычной базе данных.