Maison > Java > javaDidacticiel > Comment Hibernate gère-t-il le cycle de vie des objets associés ?

Comment Hibernate gère-t-il le cycle de vie des objets associés ?

王林
Libérer: 2024-04-18 08:42:01
original
950 Les gens l'ont consulté

Hibernate utilise différentes stratégies de cycle de vie pour gérer les objets associés en fonction du type d'association. Ces stratégies incluent la cascade unidirectionnelle un-à-plusieurs, la cascade bidirectionnelle un-à-plusieurs bidirectionnelle, la suppression orpheline plusieurs-à-un, la cascade bidirectionnelle un-à-un, etc. Dans les applications pratiques, vous pouvez choisir une stratégie appropriée en fonction de vos besoins. Par exemple, la suppression en cascade garantit que toutes les entités enfants associées sont supprimées en même temps lorsque l'entité parent est supprimée. De plus, Hibernate fournit également de riches options de configuration de mappage, telles que orphanRemoval et mappedBy, pour personnaliser davantage le traitement des objets associés.

Hibernate 如何处理关联对象的生命周期?

Comment Hibernate gère le cycle de vie des objets associés

Hibernate est un framework de mappage objet-relationnel (ORM) Java populaire qui mappe automatiquement les objets Java aux tables de base de données relationnelles. Lorsqu'il s'agit d'objets associés, Hibernate utilise différentes stratégies de cycle de vie basées sur différents types de relations.

Types de relations

Dans Hibernate, les types de relations courants incluent :

  • Unidirectionnel un-vers-plusieurs : Une entité fait référence à plusieurs entités.
  • Bidirectionnel un-à-plusieurs : Une entité fait référence à plusieurs entités et est référencée par plusieurs entités en même temps.
  • Many-to-One : Plusieurs entités font référence à une seule entité.
  • Bidirectionnel un-à-un : Une entité fait référence à une entité et est référencée par l'entité en même temps.

Stratégies de cycle de vie

Hibernate propose une variété de stratégies de cycle de vie pour gérer le cycle de vie des objets associés. Chaque stratégie a son propre comportement, en fonction du type d'association et de la configuration du mappage.

One-way un-to-many

  • Suppression en cascade : Lorsque l'entité parent est supprimée, la stratégie de suppression en cascade supprimera automatiquement toutes les entités enfants associées.
  • Persistance en cascade : Lorsque l'entité parent est persistante, la stratégie de persistance en cascade persiste automatiquement toutes les entités enfants associées.
  • Fusion en cascade : Lorsqu'une entité parent est fusionnée, la stratégie de fusion en cascade fusionne automatiquement toutes les entités enfants associées.
  • Rafraîchissement en cascade : Lorsque l'entité parent est actualisée, la stratégie d'actualisation en cascade actualise automatiquement toutes les entités enfants associées.
  • Détachement en cascade : La stratégie de détachement en cascade ne répercutera aucune opération sur les entités enfants associées.

Un-à-plusieurs bidirectionnel

  • Cascade bidirectionnelle : Cette stratégie est similaire à la cascade unidirectionnelle, mais elle cascade les opérations dans les entités parent et enfant.
  • Collection en cascade : Cette stratégie met en cascade uniquement les opérations dans les collections d'entités enfants et ne les répercute pas sur les entités parents.
  • Cascade de mappage : Cette stratégie cascade uniquement les opérations dans les mappages d'entités parents, et non vers les collections d'entités enfants.

Many-to-One

  • Suppression des orphelins : La politique de suppression des orphelins supprime automatiquement une entité enfant lorsqu'elle n'est plus référencée par aucune entité parent.
  • Application de la clé étrangère FK : Lorsque l'entité parent est supprimée, cette politique définira la clé étrangère de l'entité enfant sur NULL sans supprimer automatiquement l'entité enfant. NULL,而不会自动删除子实体。
  • FK 外键取消: 当父实体被删除时,该策略会将子实体的外键设置为 NULL
Annulation de clé étrangère FK :

Lorsque l'entité parent est supprimée, cette stratégie définira la clé étrangère de l'entité enfant sur NULL et supprimera également automatiquement l'entité enfant.

    Bidirectionnel un-à-un
  • Cascading : Cette stratégie est similaire à la stratégie en cascade bidirectionnelle dans les deux sens un-à-plusieurs.
Cascading principal :

Cette stratégie ne cascade les opérations que dans l'entité principale, et non vers les entités associées.

Cas pratique

Suppression unidirectionnelle en cascade un-à-plusieurs

@Entity
public class Parent {

    @Id
    private Long id;

    @OneToMany(mappedBy = "parent", cascade = CascadeType.ALL)
    private List<Child> children;
    // ...

}

@Entity
public class Child {

    @Id
    private Long id;

    @ManyToOne
    private Parent parent;
    // ...

}
Copier après la connexion
Dans cet exemple, si nous supprimons l'entité parent, toutes les entités enfants associées seront également automatiquement supprimées.

Cascade bidirectionnelle un-à-plusieurs bidirectionnelle

🎜
@Entity
public class Parent {

    @Id
    private Long id;

    @OneToMany(mappedBy = "parent")
    private List<Child> children;
    // ...

}

@Entity
public class Child {

    @Id
    private Long id;

    @ManyToOne
    @JoinColumn(name = "parent_id", nullable = false)
    private Parent parent;
    // ...

}
Copier après la connexion
🎜 Dans cet exemple, si nous mettons à jour l'entité parent ou supprimons l'entité enfant, l'autre extrémité de l'association sera également affectée. 🎜

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!

Étiquettes associées:
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal