2

JPA 実装の EclipseLink と MySQL サーバーをアプリケーションの永続化レイヤーに使用しています。私の問題は、既に永続化され、既に ID を持っているオブジェクトが、CascadeType.All との多対 1 の関係を通じて 2 回目に挿入されることです。

エンティティは次のとおりです。

@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;
    }
}

次のコードを実行すると、"users" テーブルに 2 つのエントリが作成されます。しかし、既存のユーザーをメッセージオブジェクトに割り当てたいだけで、新しいユーザーを作成したくありません。

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