1

我需要使用方法 1 尝试使用 createdDate 和 updatedDate 更新 postgres 数据库,但它正在插入空值。当我阅读时,@prepersist 注释似乎不适用于会话。

所以我决定使用方法 2:Hibernate @CreationTimeStamp Annotation,我添加了 hibernate-annotations maven 依赖项,但是 @CreationTimeStamp 没有解决并给出编译错误。

有人可以告诉我如何解决这个问题吗?

方法 1 使用 @Entity 和 @Table 注释的实体类

      public class Status{
      @Id
    @Column(name = "run_id")
    private int run_id; 

    @Column(name = "status")
    private String status; 

    @Temporal(TemporalType.TIMESTAMP)
    @Column(name = "created_date" , updatable=false)
    private Date created;

    @Temporal(TemporalType.TIMESTAMP)
    @Column(name = "updated_date" ,  insertable=false)
    private Date updated;

    @PrePersist
    protected void onCreate() {
        created = new Date();
    }


    @PreUpdate
    protected void onUpdate() {
        updated = new Date();
    }
//Getters and setters here
}

实现类是

  sessionFactory.getCurrentSession().save(status);  

方法 2 使用 @CreationTimeStamp 和 @updatedTimeStamp。但是maven依赖

<!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-annotations -->
<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-annotations</artifactId>
    <version>3.5.0-Final</version>
</dependency>

不将这些注释添加到类路径

4

1 回答 1

6

您使用 session.save() 方法而不是 entitymanager 是否有原因?我将发布我的应用程序示例,该示例使用实体管理器来持久化和合并实体。我也使用java.time.LocalDateTime而不是java.util.Date,这就是我不需要的原因@Temporal

这也可能有所帮助:如何在 JPA 和 Hibernate 的 Embeddable 上使用 @PrePersist 和 @PreUpdate 如果您想使用实体管理器,这将有所帮助:Hibernate EntityManager 实体类指南:

public abstract class AbstractEntity implements Serializable {
  @Id
  @GeneratedValue(strategy = GenerationType.AUTO)
  @Column(updatable = false, nullable = false)
  private Long id;

  @Column
  private LocalDateTime createdTimestamp;

  @Column
  private LocalDateTime modifiedTimestamp;

  @Version
  private Long version;

  @PrePersist
  public void setCreationDateTime() {
    this.createdTimestamp = LocalDateTime.now();
  }

  @PreUpdate
  public void setChangeDateTime() {
    this.modifiedTimestamp = LocalDateTime.now();
  }
  //Getter and setter
}

抽象数据库服务类:

public abstract class AbstractDatabaseService {
  @PersistenceContext(name = "examplePU")
  protected EntityManager entityManager;
}

示例实体存储库接口:

public interface ExampleRepository {
  ExampleEntity save(ExampleEntity exampleEntity);
}

示例实体存储库实现:

public class ExampleRepositoryImpl extends AbstractDatabaseService implements ExampleRepository , Serializable {
  @Transactional
  @Override
  public ExampleEntity save(ExampleEntity exampleEntity) {
    ExampleEntity toPersist;
    // Updating an already existing entity
    if (exampleEntity.getId() != null) {
      toPersist = entityManager.find(ExampleEntity .class, exampleEntity.getId());
      // Omitted merging toPersist with the given exampleEntity through a mapper class here
    } else {
      toPersist = exampleEntity;
    }
    try {
      toPersist = entityManager.merge(toPersist);
    } catch (Exception e) {
      // Logging e
    }
    return toPersist;
  }
}

希望这可以帮助。

于 2019-09-06T11:07:03.967 回答