gpt4 book ai didi

jpa - 将完整实体标记为 "updatable=false"

转载 作者:行者123 更新时间:2023-12-01 11:30:19 25 4
gpt4 key购买 nike

在一个应用程序中有多个实体类,禁止对数据库的更新语句。我想插入数据库并从中读取数据,但从不对现有记录进行任何更新。

Is there a way to mark a whole @Entity class as updatable=false?

  • 可以使用 @Column(updatable=false) 或类似的注释来注释每个字段,但出于显而易见的原因,我想避免这种情况。

  • 摆脱 setter 方法也不是一种选择,因为实体类也用作 DTO,而应用程序的其他部分需要这些 setter。所以这会导致对现有代码进行大量重构。

是否有另一种简单而干净的方法来实现我想要的使用 JPA 2.1/EclipseLink(+扩展)

最佳答案

您可以为此使用@PreUpdate:

@Entity
public class ReadOnlyEntity {
@PreUpdate
private void preUpdate() {
throw new UnsupportedOperationException();
}
}

这样您就永远无法更新(写入)该实体。

关于jpa - 将完整实体标记为 "updatable=false",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32715560/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com