"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Comment définir des relations avec des annotations dans Hibernate 4 à l'aide de Spring ?

Comment définir des relations avec des annotations dans Hibernate 4 à l'aide de Spring ?

Publié le 2024-11-17
Parcourir:961

How to Define Relationships with Annotations in Hibernate 4 using Spring?

Définition de relations avec des annotations dans Hibernate 4 à l'aide de Spring

Pour implémenter différents types de relations à l'aide d'annotations dans Hibernate 4 pour les classes fournies, Foo et Bar, approfondissons les détails.

Relation unidirectionnelle un-à-plusieurs :

Configurez la classe Foo avec l'annotation @OneToMany et une listepropriété. Laissez la classe Bar inchangée. Cela établit une relation un-à-plusieurs dans laquelle Foo peut avoir plusieurs objets Bar associés, mais Bar ne peut pas faire référence à Foo.

Relation bidirectionnelle un-à-plusieurs (gérée par Foo.class ):

Utilisez l'annotation @OneToOne avec cascade = CascadeType.ALL sur Foo.class. Ajoutez une annotation @JoinColumn spécifiant la colonne sur Bar.class qui doit être utilisée pour la jointure. Pour Bar.class, utilisez l'annotation @OneToOne et spécifiez mappedBy = "bar" pour indiquer que la relation est gérée par Foo.class.

Relation unidirectionnelle un-à-plusieurs à l'aide de l'utilisateur- Table de jointure gérée :

Utilisez l'annotation @OneToMany avec une annotation @JoinTable pour spécifier une table de jointure distincte. Définissez les colonnes de jointure avec les annotations @JoinColumn des deux côtés. Utilisez une classe supplémentaire pour représenter la table de jointure, si nécessaire.

Relation bidirectionnelle un-à-plusieurs utilisant le mappage de clés étrangères :

Sur Foo.class, utilisez @OneToMany(mappedBy = "bar") pour mapper la relation. Sur Bar.class, utilisez @ManyToOne(cascade = { CascadeTyep.PERSIST, CascadeType.MERGE, CascadeType.REFRESH }) avec une annotation @JoinColumn.

Many-to-Many bidirectionnel utilisant Hibernate -managed Join Table :

Utilisez @ManyToMany sur Foo.class et Bar.class, et utilisez une annotation @JoinTable pour la table de jointure, en spécifiant les colonnes de jointure.

Plusieurs-à-plusieurs bidirectionnels utilisant un objet de table de jointure géré par l'utilisateur :

Semblable à l'exemple un-à-plusieurs unidirectionnel, utilisez @OneToMany avec une annotation @JoinTable. Créez une classe distincte pour représenter la table de jointure et mappez la relation sur Foo.class et Bar.class à l'aide de @ManyToOne.

Détermination du type de récupération :

Utiliser fetchType .LAZY pour retarder le chargement des collections associées jusqu'à ce qu'elles soient accessibles. Utilisez fetchType.EAGER pour charger la collection immédiatement, mais notez que cela peut avoir un impact sur les performances. Pensez à utiliser Hibernate.initialize() dans votre classe Service pour initialiser manuellement les collections chargées paresseusement pour des cas d'utilisation spécifiques.

Détermination de la direction de la cascade :

Utilisez l'annotation @Cascade pour spécifier les options en cascade. Généralement, les changements en cascade vont dans le sens de la relation de propriété. Évitez les mises à jour ou les suppressions en cascade de l'enfant vers le parent si cela n'a pas de sens dans le contexte de l'application.

Suppression des orphelins :

Définissez orphanRemoval = true sur le Annotation @OneToMany pour qu'Hibernate supprime automatiquement les objets orphelins (c'est-à-dire ceux qui ne sont associés à aucun autre objet parent) lorsqu'ils sont supprimés de la collection sur l'objet parent.

Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3