3

私は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: エンティティのコピーが既に別のエンティティに割り当てられています。

4

1 に答える 1

1

問題は Phone クラスの結合列注釈にあると思います。employee_idまだ Employee クラスの結合列を指定していますが@Column、id フィールドの注釈は列にマップされていますid

結合列を変更/同期してみてください。

@ManyToOne(fetch = FetchType.EAGER, targetEntity=your.package.here.Employee.class)
@JoinColumn(name = "id")
private Employee owner;

また

従業員.java

@Id
@Column(name = "employee_id", unique = true, nullable = false)
@GeneratedValue(strategy = javax.persistence.GenerationType.IDENTITY)
private Integer id;

電話.java

@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "employee_id", targetEntity=your.package.here.Employee.class)
private Employee owner;
于 2012-11-09T00:44:22.717 に答える