JPA: проблема с сохранением ограничения внешнего ключа - PullRequest
3 голосов
/ 28 июля 2010

Я получил две сущности:

Клиентский субъект

@Entity
public class Customer {

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;

private String name;

@OneToMany(mappedBy="customer", cascade=CascadeType.ALL)
private List<Facility> facilities;

//Setter and Getter for name and facilities

public void addFacility(Facility facility){
    this.facilities.add(facility);
}
}

Объект Entity

@Entity
public class Facility {

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;

@ManyToOne
@JoinColumn(name="CUSTOMER_FK")
private Customer customer;

private String name;

//Setter and Getter, equals and hashcode
...
}

Так что в моем основном я делаю это

    Customer customer = new Customer();
    customer.setName("Wake Forest University");
    Facility facility = new Facility();
    facility.setName("Tom Cruise");
    EntityManager entityManager = Persistence.createEntityManagerFactory("EntityClassPU").createEntityManager();
    entityManager.getTransaction().begin();
    customer.addFacility(facility);
    entityManager.persist(customer);
    entityManager.getTransaction().commit();

Wake Forest University успешно вставлен в Customer, а Tom Cruise успешно вставлен в Facility, однако внутри Facility значение CUSTOMER_FK равно нулю, что свидетельствует о том, что я не смог сохранить постоянный внешний ключ , Что я тут не так сделал?

1 Ответ

8 голосов
/ 28 июля 2010

Ваше отношение между Customer и Facility является двунаправленной ассоциацией, вы должны управлять обеими сторонами ассоциации. Вы можете сделать это вручную, но я предлагаю сделать это методом addFacility():

public void addFacility(Facility facility){
    if (this.facilities == null) { 
        this.facilities = new ArrayList<Facility>();
    } 
    this.facilities.add(facility);
    facility.setCustomer(this); // that's the part you're currently missing
}
...