Oracle
 sql >> Datenbank >  >> RDS >> Oracle

Wie verweise ich mit JPA/Hibernate auf die ID eines Elternteils in der ID eines Kindes?

Die Zuordnungen sollten wie folgt aussehen:

@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;
}

Wenn die Cascade-Option gesetzt ist, müssen Sie nur den Aufruf zum Speichern von firstClass tätigen:die zugehörige secondClass wird automatisch beibehalten – vorausgesetzt, Sie setzen beide Seiten der Beziehung in Ihrem In-Memory-Modell, d. h.

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