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")
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"
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; }
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!