Подтвердить что ты не робот

@OneToMany отображает карты на _____

Что mappedBy отображает на? Или, скорее, на что он должен ориентироваться?

Поле headers ниже соответствует @Entity Foo согласно @OneToMany docs? И тогда Foo будет оберткой для javax.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;
    }
}
4b9b3361

Ответ 1

Да, нужна оболочка для javax.mail.Header, в общем случае вы не можете перенести непосредственно произвольные классы, особенно те, которые не являются Serializable. Также они не могут быть элементами списка, который проектирует отношения между объектами.

Значение mappedBy - это имя поля, владеющего стороной двунаправленного отношения. Для примера предположим, что объект Article имеет отношение "один ко многим" к объекту Foo:

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

Теперь мы знаем, что должен быть другой конец этого отношения, и это атрибут, который находится в объекте Foo, имеет статью как тип и называется статьей:

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

Собственная сторона (в данном случае статья в Foo) используется, когда двунаправленная связь сохраняется в базе данных. В спецификации JPA 2.0 это сказано со следующими словами:

Двунаправленные отношения между управляемыми объектами будут сохраняться основанные на ссылках, принадлежащих владелической стороне отношений. это ответственность разработчиков за сохранение содержащихся в памяти ссылок на стороне обладателя и тех, которые находятся на обратной стороне, согласующейся с друг друга, когда они меняются. В случае однонаправленного одностороннего и отношения "один ко многим", ответственность разработчиков лежит на убедитесь, что семантика отношений соблюдается.

Ответ 2

Отметьте здесь: документация

Соответствующая часть:

      mappedBy
      The field that owns the relationship.

Это своеобразное объяснение. Вам нужны примеры?

Если у вашего Article есть много объектов Header, например, тогда Article является владельцем realationship, поскольку статья имеет множество заголовков.