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; ... }
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!