Örneğimde, Employee
, ile CascadeType.PERSIST
numaralı Department
ilişkisine sahiptir. Birden Employee
, devam ediyorsa JPA CascadeType.PERSIST nasıl çalışır?
Neden
EntityManager
tüm
Employee
kayıtları için tek
Department
kayıt devam eder? Biz
CascadeType.PERSIST
, bir
Employee
kalıcıdır edilirken, bir
Department
rekor her
Employee
kayıt için yeniden oluşturulacak kullanırsanız
Beklentim vardır.
Employee.java
@Entity
public class Employee {
private String id;
private String name;
@OneToOne(cascade = CascadeType.PERSIST)
@JoinColumn(name = "DEP_ID", referencedColumnName = "ID")
private Department department;
-----
}
Department.java
@Entity
public class Department implements Serializable {
private String id;
private String name;
}
Test.java
public void insert() {
em = emf.createEntityManager();
em.getTransaction().begin();
Department department = new Department("Test Department");
for(int i=1; i <= 10; i++) {
Employee e = new Employee("EMP" + i, department);
em.persist(e);
}
em.getTransaction().commit();
em.close();
}
Sonuç:
Employee Table Department Table
================= ==============================
ID Name DEP_ID ID NAME
================= ==============================
1 EMP1 1 1 Test Department
2 EMP2 1
3 EMP3 1
4 EMP4 1
5 EMP5 1
6 EMP6 1
7 EMP7 1
8 EMP8 1
9 EMP9 1
10 EMP10 1
UNIQUE kısıtı vardır üstünde). OneToOne ek açıklamalarına rağmen DEP_ID'nin bu durumda neden bir UNIQUE kısıtlaması olmadığını açıklayan herhangi biri var mı? – Chris