@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;
}
}
Ответы
Ответ 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, поскольку статья имеет множество заголовков.