использования.
Есть у меня Topic [1..n] Comment. И, имея orphanRemoval=true, вызываю метод:
@Transactional public void removeComment() {
commentRepository.findById(1L).orElseThrow().getComments().remove(0);}
Можно идти в обратную сторону и искать все комменты where comment.topic.id = someId, а потом удалять их. Этот подход явный и понятный. И возникает вопрос, тогда зачем полагаться на oprhanRemoal? Ведь это от части потенциальное место ошибок, когда удаляем дочерние сущности через коллекцию в Transactional методе, или я не прав?
А в чем будет ошибка?)в том что он попробует удалить некоторые комменты 2 раза?)мне кажется ошибки не будет и все удалится хорошо. Орфан это про то,что тебе не нужны самописные операции по удалению тех комментов,которые не имеют топика. Если у тебя считается нормальным коммент без топика тогда орфан юзать не стоит)
Просто может быть баг, из-за незнания, как работает удаление дочерних сущностей. К примеру внутри removeComment я могу вызвать другой метод foo(comments), передав topic.getComments(). Дальше случайно изменить коллекцию (мутировать) и это запишется неявно в базу.
в контексте spring data мне показалось, что orphan - это в основном про возможность удалять дочерние сущности, мутируя коллекцию comments. Если коммент без топика может существовать, то скорее в первую очередь нужно проверить не стоит ли случайно cascade remove.
Так если топик удаляется,то без разницы,изменишь ты перед этим его коллекцию комментов,или нет)
Обсуждают сегодня