Oracle
 sql >> Database >  >> RDS >> Oracle

Come fare riferimento all'ID di un genitore nell'ID di un bambino con JPA/Hibernate?

Le mappature dovrebbero essere le seguenti:

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

Con l'opzione Cascade impostata, dovrai solo effettuare la chiamata per salvare firstClass:la secondClass associata verrà mantenuta automaticamente, supponendo che tu abbia impostato entrambi i lati della relazione nel tuo modello in memoria, ad es.

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