@OneToMany映射通过映射到 _____

2022-09-01 10:54:18

映射到什么?或者,更确切地说,它应该映射到什么?mappedBy

下面的字段映射到每个文档?然后会是一个包装器 ?headers@EntityFoo@OneToManyFoojavax.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的包装器是必需的,通常你不能直接保留任意类,特别是那些不可序列化的类。此外,它们不能是设计实体之间关系的列表元素。

mappedBy 的值是拥有双向关系的一侧的字段的名称。举个例子,让我们假设文章实体确实与Foo实体有一对多的关系:

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

现在我们知道这种关系必须有另一端,它是属性,它位于Foo实体,确实将Article作为类型并命名为article

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

当双向关系持久化到数据库时,将使用拥有方(在本例中为 Foo 中的文章)。在 JPA 2.0 规范中,这用以下文字来讲述:

托管实体之间的双向关系将基于关系的拥有方持有的引用进行持久化。开发人员有责任保持内存中的引用在所属方,而那些保留在反向侧的引用在更改时彼此一致。在单向一对一和一对多关系的情况下,开发人员有责任确保遵守关系的语义。


答案 2

查看此处:文档

相关部分是:

      mappedBy
      The field that owns the relationship.

这是不言自明的。你想要例子吗?

例如,如果您有很多对象,那么就拥有了实现权,因为文章有很多标题。ArticleHeaderArticle


推荐