web-dev-qa-db-ja.com

@OneToMany mappedByは_____にマップされます

mappedBy maptoとは何ですか?または、むしろ、何にマップする必要がありますか?

以下のheadersフィールドは、@Entitydocs ?に従って@OneToManyFooにマッピングされます。 Foojavax.mail.Headerのラッパーになりますか?

package net.bounceme.dur.usenet.model;

import Java.io.Serializable;
import Java.util.ArrayList;
import Java.util.List;
import Java.util.logging.Level;
import Java.util.logging.Logger;
import javax.mail.Header;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.persistence.*;

@Entity
public class Articles implements Serializable {

    private static final long serialVersionUID = 1L;
    private static final Logger LOG = Logger.getLogger(Articles.class.getName());
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;
    @Column
    private String subject;

    @OneToMany(mappedBy="foo")  //a wrapper for Header is needed?
    private List<Header> headers = new ArrayList<>();

    public Articles() {
    }

    public Articles(Message message) {
        try {
            subject = message.getSubject();
        } catch (MessagingException ex) {
            Logger.getLogger(Articles.class.getName()).log(Level.SEVERE, null, ex);
        }
    }

    public Long getId() {
        return id;
    }

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

    @Override
    public int hashCode() {
        int hash = 0;
        hash += (id != null ? id.hashCode() : 0);
        return hash;
    }

    @Override
    public boolean equals(Object object) {
        // TODO: Warning - this method won't work in the case the id fields are not set
        if (!(object instanceof Articles)) {
            return false;
        }
        Articles other = (Articles) object;
        if ((this.id == null && other.id != null) || (this.id != null && !this.id.equals(other.id))) {
            return false;
        }
        return true;
    }

    @Override
    public String toString() {
        return subject;
    }

    public String getSubject() {
        return subject;
    }

    public void setSubject(String subject) {
        this.subject = subject;
    }
}
29
Thufir

はい。javax.mail.Headerのラッパーが必要です。一般に、特にSerializableではないクラスではなく、任意のクラスを直接永続化することはできません。また、エンティティ間の関係を設計するリストの要素にすることはできません。

MappedByの値は、双方向関係の所有側であるフィールドの名前です。例として、ArticleエンティティがFooエンティティと1対多の関係にあると仮定します。

@OneToMany(mappedBy="article")
private List<Foo> headers;

これで、この関係のもう一方の端がなければならないことがわかります。これは、Fooエンティティに位置する属性であり、タイプとしてArticleを持ち、名前はarticleです。

@Entity
public class Foo {
...
   @ManyToOne
    Article article;
}

所有側(この場合はFooの記事)は、データベースとの双方向の関係が維持されるときに使用されます。 JPA 2.0仕様では、これは次の言葉で伝えられます。

管理対象エンティティ間の双方向の関係は、関係の所有側が保持する参照に基づいて永続化されます。開発者は、メモリ内の参照が所有側に保持され、逆側に保持されている参照が変更されたときに互いに整合性を保つようにする責任があります。単方向の1対1および1対多の関係の場合、関係のセマンティクスが順守されることを保証するのは開発者の責任です。

33
Mikko Maunu

こちらで確認してください:ドキュメント

関連する部分は次のとおりです。

      mappedBy
      The field that owns the relationship.

それは一種の自明です。例が必要ですか?

たとえば、Articleに多くのHeaderオブジェクトがある場合、Articleは記事has多くのヘッダー。

0
Adam Arold