Maison > Java > javaDidacticiel > JPA : @JoinColumn vs mappedBy : quand utiliser lequel ?

JPA : @JoinColumn vs mappedBy : quand utiliser lequel ?

DDD
Libérer: 2024-12-15 22:39:24
original
935 Les gens l'ont consulté

JPA: @JoinColumn vs. mappedBy: When to Use Which?

Comprendre JPA JoinColumn vs mappedBy

Dans JPA, l'annotation @JoinColumn définit une colonne de clé étrangère dans l'entité actuelle qui fait référence à une colonne dans l’entité référencée. En revanche, l'attribut mappedBy spécifie que l'entité actuelle est le côté inverse d'une relation bidirectionnelle, où la propriété de la clé étrangère réside dans l'entité référencée.

Propriété et relations inverses

Lors de l'utilisation de @JoinColumn, l'entité avec l'annotation est considérée comme le « propriétaire » de la relation. En tant que telle, sa table contiendra la colonne de clé étrangère liée à la table référencée. D'un autre côté, l'attribut mappedBy signifie que l'entité avec cette annotation est le côté « inverse » de la relation. La propriété de la clé étrangère réside dans l'entité référencée par mappedBy.

Exemple d'annotation

Voici un exemple qui illustre la différence :

@Entity
public class Company {

    @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)
    @JoinColumn(name = "companyIdRef", referencedColumnName = "companyId")
    private List<Branch> branches;
    ...
}

@Entity
public class Company {

    @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "companyIdRef")
    private List<Branch> branches;
    ...
}
Copier après la connexion

Dans le premier bloc de code, @JoinColumn est utilisé, faisant de Company le propriétaire de la relation. La table Company contiendra la colonne de clé étrangère « companyIdRef » qui fait référence à la colonne « companyId » dans la table Branch.

Dans le deuxième bloc de code, mappedBy est utilisé, faisant de Company le côté inverse de la relation. Branch est désormais propriétaire et sa table contiendra la colonne de clé étrangère "companyIdRef" qui fait référence à la colonne "companyId" de la société.

Relations bidirectionnelles

Lors de l'utilisation de mappedBy, vous pouvez accéder à l'entité associée des deux côtés de la relation, permettant une navigation bidirectionnelle. Cela n'est pas possible lorsque vous utilisez @JoinColumn seul, car la propriété de la clé étrangère réside dans une seule entité.

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