私は2つのテーブルを持っています。1 つは従業員と呼ばれ、もう 1 つは電話と呼ばれ、従業員は複数の電話を持つことができます。
従業員クラス:
@Entity
@Table(name = "employee")
public class Employee {
@Id
@Column(name = "id", unique = true, nullable = false)
@GeneratedValue(strategy = javax.persistence.GenerationType.IDENTITY)
private Integer id;
@Column(name = "name", unique = true, nullable = false, length = 25)
private String name;
@OneToMany(mappedBy="owner", fetch= FetchType.EAGER, orphanRemoval=true, cascade={CascadeType.ALL})
private List<Phone> phones;
電話クラス:
@Entity
@Table(name = "phone")
public class Phone {
@Id
@Column(name = "id", unique = true, nullable = false)
@GeneratedValue(strategy = javax.persistence.GenerationType.IDENTITY)
private long id;
@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "employee_id")
private Employee owner;
@Column(name = "phone_type", nullable = false, length = 25)
private String phoneType;
@Column(name = "phone_number", nullable = false, length = 25)
private String phoneNumber;
既存の従業員に電話を追加するとします。私はこれをやっています:
Phone phone = new Phone();
phone.setOwner(employee);
phone.setPhoneNumber("999-555-0001");
phone.setPhoneType("home");
employee.getPhones().add(phone);
dao.merge(employee); // Is it possible to get this to both persist new phones and update existing phones that were changed?
phoneSet 内の一部の電話が既に保持されていることを考えると、新しい電話をマージする方法がわかりません。各電話を手動で永続化する必要がありますか? 例をいただければ幸いです。カスケードを調べましたが、機能しないようです。私が受け取っているエラーは次のとおりです: java.lang.IllegalStateException: エンティティのコピーが既に別のエンティティに割り当てられています。