1

这是实体片段........忽略 DaoObject..它只是将自动生成的 Id 添加到它的子类的每个实体。

我已经强调了哪些是持久化内容所必需的。最终它无法为流表中的 contentid 列添加值。它虽然使用以下代码在内容和流表中添加了一行..

请检查并帮助我解决问题

          Content newContent = TestHelper.contentFactory(null, "streamForCREATE_IT", xxxx, 100);
          Stream stream = TestHelper.streamFactory(null, "name", "appname",);
          **stream.setContent(newContent);
          List<Stream> streams = new ArrayList<Stream>();
          streams.add(stream);
          newContent.setStreams(streams);**


@Entity
public class Content extends DaoObject {
  public Content() {
  };

  private String name;
  private ContentType type;
  @OneToMany(fetch = FetchType.EAGER, mappedBy = "content", cascade = {CascadeType.PERSIST,CascadeType.MERGE}, orphanRemoval = true)
  @JsonManagedReference
  private List<Stream> streams = new ArrayList<Stream>();
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }
  public List<Stream> getStreams() {
    return streams;
  }
  public void setStreams(List<Stream> streams) {
    this.streams = streams;
  }
    public void addStream(Stream newStream) {
    if (streams == null) {
      streams = new ArrayList<Stream>();
    }
    newStream.setContent(this);
    streams.add(newStream);
  }
}

@Entity
public class Stream extends DaoObject {
  public Stream() {
  }
  @ManyToOne(fetch = FetchType.EAGER, cascade = CascadeType.ALL)
  @JoinColumn(name = "contentid")
  @JsonBackReference
  private Content content;**
  private String name;
  private String appName;
  public Content getContent() {
  return content;
  }
  public void setContent(Content content) {
  this.content = content;
  }
  public String getName() {
  return name;
  }
  public void setName(String name) {
  this.name = name;
  }
  public String getAppName() {
  return appName;
  }
  public void setAppName(String appName) {
  this.appName = appName;
  }
} 

这是来自 mysql 工作台的图像。

在此处输入图像描述

4

1 回答 1

0

该死的太愚蠢了。我正在测试发生这种情况的 REST API,我确实为内容和每个流的内容正确设置了流,但这一切都发生在 JSON 转换之前。当在 dao 中重新创建此关联时,它起作用了。感谢@AndreiI 提出正确的问题,帮助我解决了这个问题。

于 2014-09-23T07:10:53.657 回答