Maison > Java > javaDidacticiel > Pourquoi les enregistrements orphelins ne sont-ils pas supprimés avec JPA CascadeType.ALL ?

Pourquoi les enregistrements orphelins ne sont-ils pas supprimés avec JPA CascadeType.ALL ?

Susan Sarandon
Libérer: 2024-10-31 00:22:30
original
339 Les gens l'ont consulté

 Why Aren't Orphan Records Being Deleted with JPA CascadeType.ALL?

JPA CascadeType.ALL ne supprime pas les orphelins

Lors de l'utilisation de JPA avec le mappage @OneToMany avec cascade = CascadeType.ALL, il est prévu que cet orphelin les nœuds seront supprimés lorsque l'entité parent est supprimée. Cependant, dans certains cas, des enregistrements orphelins peuvent persister dans la base de données.

Solution :

Avec Hibernate :

Si en utilisant Hibernate, l'annotation CascadeType.DELETE_ORPHAN peut être ajoutée en conjonction avec CascadeType.ALL :

<code class="java">@OneToMany (cascade = {CascadeType.ALL, CascadeType.DELETE_ORPHAN}, fetch = FetchType.EAGER, mappedBy = "owner")
private List<Bikes> bikes;</code>
Copier après la connexion

Sans Hibernate :

Sans Hibernate, les enregistrements orphelins doivent être explicitement supprimé avant de supprimer l'enregistrement principal :

  1. Récupérez la ligne principale à supprimer.
  2. Récupérez les éléments enfants.
  3. Supprimez tous les éléments enfants.
  4. Supprimez la ligne principale.
  5. Fermez la session.

JPA 2.0 :

JPA 2.0 introduit l'indicateur orphanRemoval :

<code class="java">@OneToMany(mappedBy="foo", orphanRemoval=true)</code>
Copier après la connexion

Avec orphanRemoval = true, les enregistrements orphelins seront supprimés lorsque l'entité parent est supprimée sans qu'il soit nécessaire de supprimer manuellement.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal