Oracle
 sql >> Base de données >  >> RDS >> Oracle

Comment référencer l'identifiant d'un parent dans l'identifiant d'un enfant avec JPA/Hibernate ?

Les mappages doivent être comme ci-dessous :

@Entity
@Table(name = "MY_SCHEMA.MY_TABLE_A")
@Component
public class FirstClass implements Serializable {

    @Id
    @SequenceGenerator(name = "MY_SEQ", sequenceName = "MY_SCHEMA.MY_SEQ", allocationSize = 1)
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "MY_SEQ")
    @Column(name = "MY_ID")
    private Long myId;

    @OneToOne(mappedBy = "firstClass", cascade = CascadeType.ALL)
    private SecondClass secondClass;
}

@Entity
@Table(name = "MY_SCHEMA.MY_TABLE_B")
@Component
public class SecondClass implements Serializable {

    @Id
    @JoinColumn(name = "MY_ID", referencedColumnName = "MY_ID")
    @OneToOne
    private FirstClass firstClass;
}

Avec l'option Cascade définie, vous n'aurez qu'à effectuer l'appel pour enregistrer firstClass :la secondeClasse associée sera conservée automatiquement - en supposant que vous définissez les deux côtés de la relation dans votre modèle en mémoire, c'est-à-dire

firstClass.setSecondClass(secondClass);
secondClass.setFirstClass(firstClass);