I am having problems removing another entity through cascade delete-orphan. It works when I clear the associated set collection, but not when I make the set collection null.
In the version 5 of Hibernate the problem is very similar but an exception is thrown instead: "A collection with cascade="all-delete-orphan" was no longer referenced by the owning entity instance". To tackle that I had to switch from null values to empty collections.
The issue in Hibernate is posted here: https://hibernate.atlassian.net/browse/HHH-9940
I think its because hibernate uses its own collection implementations (which is why the docs say you MUST declare collections as interfaces, not implementations), and the collection implementations obey the semantics of you transitive persistence settings. So, when you do
cats.getBla().clear()
the getBla() part is the hibernate collection implementation, which knows to remove the children from the session when clear() is called.
When you do
cats.setBla(null);
you haven't removed the collection, you have changed the parent's reference to the collection to null. The collection probably still exists in the session.