2

我将 JPA 实现 EclipseLink 和 MySQL 服务器用于我的应用程序的持久层。我的问题是,一个已经持久化并且已经有一个 id 的对象,通过与 CascadeType.All 的多对一关系被第二次插入。

这里的实体:

@Entity
@Table(name = "messages")
public class Message extends DbObject {

    @ManyToOne(cascade = CascadeType.ALL)
    @JoinColumn(name = "user_id")
    public User author;

    public String message = "";

    public Timestamp timestamp;

       // Getters and setters removed ....
}


@Entity
@Table(name = "users")
public class User extends DbObject {

    private String name;

    // Getters and setters removed ....
}


@MappedSuperclass
public abstract class DbObject {

    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE)
    private long id;

    public long getId() {
        return id;
    }

    public void setId(long id) {
        this.id = id;
    }
}

当我运行以下代码时,我的“用户”表中有两个条目。但我只想将已经存在的用户分配给消息对象,而不是创建新用户。

User user = getCurrentUser(); // The user object is already persistent  

Message msg = new Message();
msg.setUser(user);
EntityManager em = createEntityManager();
em.getTransaction().begin();
em.persist(msg);
em.getTransaction().commit();
em.close();
4

1 回答 1

2

用户与您用来持久化消息的 entityManager 分离,并且在与用户的关系上设置了级联持久化,JPA 要求持久化也发生在分离的用户上。选项是 A) 使用当前持久性读取它,以便对其进行管理。Persist 是对托管实体的无操作,而不是级联。B)删除消息->用户关系上的所有级联 C)对消息实例使用合并而不是持久化。Merge 仍将保留它,但会将用户状态正确复制到托管用户实例中。

于 2013-10-06T22:22:13.097 回答