Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Hibernuj OneToMany z niedopasowanymi złożonymi kluczami podstawowymi

Boże, to był koszmar. W końcu to rozgryzłem i patrząc wstecz, naprawdę powinienem pomyśleć o tym wcześniej. Oto, co zadziałało dla mnie na wypadek, gdyby ktoś inny miał podobny problem w przyszłości.

Problem polega na tym, że osadzony identyfikator Table2 był mapowany bezpośrednio na te same jednostki, co osadzony identyfikator Table1. Tego właśnie chcę z bazą danych, ale nie z Hibernate. Zamiast tego dwa pola dla TableA i TableB powinny być reprezentowane przez samą tabelę Table1, a skojarzenia są zapisywane w celu dopasowania. Muszą zawierać insertable=false i updatable=false, aby Table2 nie mogło wprowadzać żadnych zmian w Table1. W moim przypadku chcę tylko jednokierunkowej relacji. Tabela1 może następnie użyć parametru mappedBy adnotacji @OneToMany, aby mapować bezpośrednio na siebie. Dzięki temu Table1 może kontrolować relację. Tak więc kod powinien wyglądać następująco:

@Entity
@AssociationOverrides({
        @AssociationOverride(name = "pk.tableA",
                joinColumns = @JoinColumn(name = "FK_TABLE_A", nullable=false)),
        @AssociationOverride(name = "pk.tableB",
                joinColumns = @JoinColumn(name = "FK_TABLE_B", nullable=false)) })
@Table(name="TABLE1")
public class Table1 extends BaseObject implements Serializable
{
    private static final long serialVersionUID = 1L;

    private Table1Id pk = new Table1Id ();

    @EmbeddedId
    public Table1Id getPk() {
        return pk;
    }
    public void setPk(Table1Id pk) {
        this.pk = pk;
    }

    private TableC tableC;
    @ManyToOne
    @JoinColumn(name = "FK_TABLE_C", referencedColumnName = "ID", nullable = true)
    public TableC getTableC() {
        return this.tableC;
    }
    public void setTableC(TableC tableC) {
        this.tableC = tableC;
    }

    private List<Table2> table2s;
    @OneToMany(mappedBy="pk.table1", cascade = {CascadeType.ALL}, orphanRemoval=true, fetch=FetchType.EAGER)
    public List<Table2> getTable2s() {
        return table2s;
    }
    public void setTable2s(List<Table2> table2s) {
        this.table2s= table2s;
    }

    @Override
    public boolean equals(Object o) {
        ...
    }

    @Override
    public int hashCode() {
        ...
    }

    @Override
    public String toString() {
        ...
    }
}

@Entity
@AssociationOverrides({
        @AssociationOverride(name = "pk.table1",
                joinColumns = {
                        @JoinColumn(name = "FK_TABLE_A", nullable=false, insertable=false, updatable=false),
                        @JoinColumn(name = "FK_TABLE_B", nullable=false, insertable=false, updatable=false)
                        }),
        @AssociationOverride(name = "pk.tableD",
                joinColumns = @JoinColumn(name = "FK_TABLE_D", nullable=false)) })
@Table(name="TABLE2")
public class Table2 extends BaseObject implements Serializable
{
    private static final long serialVersionUID = 1L;

    private Table2Id pk = new Table2Id();

    @EmbeddedId
    public Table2Id getPk() {
        return pk;
    }
    public void setPk(Table2Id pk) {
        this.pk = pk;
    }

    private Double value;
    @Column(name = "VALUE", nullable = false, insertable = true, updatable = true, precision = 2)
    @Basic
    public Double getValue() {
        return this.value;
    }
    public void setValue(Double value) {
        this.value = value;
    }

    @Override
    public boolean equals(Object o) {
        ...
    }

    @Override
    public int hashCode() {
        ...
    }

    @Override
    public String toString() {
        ...
    }
}

@Embeddable
public class Table2Id extends BaseObject implements Serializable 
{
    private static final long serialVersionUID = 1L;

    private Table1 table1;
    @ManyToOne
    @JoinColumn(nullable=false)
    public Table1 getTable1() {
        return this.table1;
    }
    public void setTable1(Table1 table1) {
        this.table1 = table1;
    }

    private TableD tableD;
    @ManyToOne
    @JoinColumn(nullable=false)
    public TableD getTableD() {
        return this.tableD;
    }
    public void setTableD(TableD tableD) {
        this.tableD = tableD;
    }

    @Override
    public boolean equals(Object o) {
        ...
    }

    @Override
    public int hashCode() {
        ...
    }

    @Override
    public String toString() {
        ...
    }
}



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Hibernate 4.3.5 ignoruje właściwość konfiguracyjną v$session.program

  2. Zapytanie o ograniczenie Oracle po wartości search_condition

  3. Jak dodać ograniczenie wartości null do kolumny zawierającej wartości null?

  4. ORA-12728:nieprawidłowy zakres w wyrażeniu regularnym

  5. Ponieważ SQL Server nie zawiera pakietów, co robią programiści, aby go obejść?