JPA: persist не вставляется в таблицу соединений

#jpa-2.0 #one-to-many #cascade #jointable

#jpa-2.0 #один ко многим #каскад #объединяемый

Вопрос:

Все,

Я использую JPA для этого приложения и аннотации для сопоставления объектов. У меня есть объект с именем UserStory, а другой — с именем Revision. Для UserStory существует OneToMany для пересмотра.

 @Entity
@Table(name = "user_story")
@NamedNativeQueries({
    @NamedNativeQuery(name = "storyBacklog", query = "SELECT userstory.rank AS rank, userstory.description AS description, userstory.estimate AS estimate, userstory.name AS name, "
          "userstory.id AS id, userstory.status AS status FROM user_story userstory ORDER BY userstory.rank ASC", resultClass = UserStory.class),
    @NamedNativeQuery(name = "getCos", query = "SELECT conditions.cos As cos FROM story_cos conditions WHERE conditions.story_id=?1", resultSetMapping = "cosMapping") })
@SqlResultSetMappings({ @SqlResultSetMapping(name = "cosMapping", columns = @ColumnResult(name = "cos")) })
public class UserStory implements Serializable {

  private static final long serialVersionUID = 248298400283358441L;

  @Id
  @GeneratedValue(strategy = GenerationType.AUTO)
  private Long id;
  ...
  @OneToMany(cascade = CascadeType.ALL)
  @JoinTable(name = "story_revisions", joinColumns = @JoinColumn(name = "story_id"), inverseJoinColumns = @JoinColumn(name = "revision_id"))
  private Set<Revision> revisions;
  

вот объект ревизии:

 @Entity
@Table(name = "revision")
public class Revision implements Serializable {

  private static final long serialVersionUID = -1823230375873326645L;

  @Id
  @GeneratedValue(strategy = GenerationType.AUTO)
  private Long id;

  @Column(nullable = false)
  private String description;

  @Column(name = "date_created", nullable = false)
  @Temporal(TemporalType.TIMESTAMP)
  private Date creationDate;
  

Когда я создаю UserStory; Я добавляю к нему ревизию,

но таблица соединений не заполняется, если сначала я сохраняю историю, затем добавляю ревизию и объединяю ее.

вот код для сохранения истории пользователей:

   public UserStory saveUserStory(UserStory userStory) {
    Revision revision = new Revision();
    revision.setCreationDate(new Timestamp(System.currentTimeMillis()));
    revision.setDescription("User story created");
    Set<Revision> revisions = new HashSet<Revision>();
    revisions.add(revision);
    userStory.setRevisions(revisions);
    return storyDao.create(userStory);
  }
  

в StoryDao я вызываю метод persist:

 @Transactional(readOnly = false)
  public UserStory create(UserStory userStory) {
    if (userStory.getRank() == null) {
      Integer highestRank = 0;
      highestRank = (Integer) entityManager.createNativeQuery("select max(rank) from user_story")
          .getSingleResult();
      if (highestRank != null)
        highestRank  = 1;
      else
        highestRank = new Integer(1);
      userStory.setRank(highestRank);
    }
    entityManager.persist(userStory);
    LOGGER.debug("Added User Story with id "   userStory.getId());
    entityManager.detach(userStory);
    return userStory;
  }
  

вот SQL из ЖУРНАЛОВ

 Hibernate: 
    insert 
    into
        user_story
        (description, estimate, name, rank, status) 
    values
        (?, ?, ?, ?, ?)
Hibernate: 
    insert 
    into
        revision
        (date_created, description) 
    values
        (?, ?)
Hibernate: 
    select
        revision0_.id as id5_0_,
        revision0_.date_created as date2_5_0_,
        revision0_.description as descript3_5_0_ 
    from
        revision revision0_ 
    where
        revision0_.id=?
Hibernate: 
    select
        userstory0_.id as id3_1_,
        userstory0_.description as descript2_3_1_,
        userstory0_.estimate as estimate3_1_,
        userstory0_.name as name3_1_,
        userstory0_.rank as rank3_1_,
        userstory0_.status as status3_1_,
        revisions1_.story_id as story1_3_3_,
        revision2_.id as revision2_3_,
        revision2_.id as id5_0_,
        revision2_.date_created as date2_5_0_,
        revision2_.description as descript3_5_0_ 
    from
        user_story userstory0_ 
    left outer join
        story_revisions revisions1_ 
            on userstory0_.id=revisions1_.story_id 
    left outer join
        revision revision2_ 
            on revisions1_.revision_id=revision2_.id 
    where
        userstory0_.id=?
  

Отсюда я вижу, что он сохраняет историю пользователя и ревизию, но затем пытается запустить соединение, чтобы проверить, существует ли связь, прежде чем выполнять вставку в таблицу соединений. Который, конечно, он не найдет, потому что я создаю этот объект.

Как в этом случае заполнить таблицу соединений?

Ответ №1:

Теперь работает. Вот обновленный код

 revisions.add(revision);
userStory = storyDao.create(userStory);
userStory.setRevisions(revisions);
return storyDao.update(userStory);
  

Я все еще не уверен, зачем это требуется; двухэтапный метод, в котором я сохраняю объект, затем обновляю его.