Maison > Java > javaDidacticiel > JoinColumn vs MappedBy : comment choisir la bonne annotation JPA pour les relations entre entités ?

JoinColumn vs MappedBy : comment choisir la bonne annotation JPA pour les relations entre entités ?

DDD
Libérer: 2024-12-18 05:34:20
original
1049 Les gens l'ont consulté

JoinColumn vs. MappedBy: How to Choose the Right JPA Annotation for Entity Relationships?

JDBC : JoinColumn versus MappedBy

Dans l'API Java Persistence (JPA), JoinColumn et mappedBy sont deux annotations utilisées pour définir les relations entre les entités. Comprendre la distinction entre ces annotations est essentiel pour une modélisation efficace des données et des interactions avec les bases de données.

JoinColumn : Propriété et clés étrangères

L'annotation @JoinColumn indique que l'entité annotée avec c'est le propriétaire de la relation. Cela signifie que la table correspondante conserve une colonne de clé étrangère faisant référence à la clé primaire de la table référencée. Par exemple, dans l'exemple de code fourni :

@JoinColumn(name = "companyIdRef", referencedColumnName = "companyId")
Copier après la connexion

L'entité Société est propriétaire de la relation avec l'entité Branche. La colonne companyIdRef de la table Branch servira de clé étrangère référençant la colonne companyId de la table Company.

MappedBy : Inverse Relations

D'autre part, la L'annotation @mappedBy signifie que l'entité annotée avec elle se trouve du côté inverse de la relation. Le propriétaire de la relation réside dans l'entité « autre », qui est référencée par l'attribut mappedBy. Dans ce scénario :

@mappedBy = "companyIdRef"
Copier après la connexion

L'entité Branche est l'inverse de la relation avec l'entité Société. L'attribut companyIdRef dans l'entité Branch établit une relation bidirectionnelle, permettant d'accéder à l'entité Société à partir de l'entité Branch.

Annotations correctes pour l'exemple de code

Pour pour obtenir une relation entièrement bidirectionnelle, les annotations correctes pour l'exemple de code seraient :

@Entity
public class Company {
    @OneToMany(mappedBy = "company",
               orphanRemoval = true,
               fetch = FetchType.LAZY,
               cascade = CascadeType.ALL)
    private List<Branch> branches;
}

@Entity
public class Branch {
    @ManyToOne(fetch = FetchType.LAZY)
    @JoinColumn(name = "companyId")
    private Company company;
}
Copier après la connexion

En annotant correctement le relations, vous pouvez naviguer et manipuler efficacement les données entre les entités liées dans vos applications Java.

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