使用 JPA 进行更新时如何排除实体字段

2024-01-02

有没有办法使字段在更新操作时不持久,但在使用 JPA - Hibernate 4 创建操作时持久?

我用这种方式尝试过

@Transient
@Id
@Column(name = "USER_NAME", nullable = false, length = 75)
private String userName;

但使用 @Transient 注释时,该字段在所有 CRUD 操作中都是瞬态的,我想要一种方法来指定仅在此操作上是持久的(创建)。

有没有办法做到这一点?

Thanks!


你需要设置updatable的属性@Column注释到false:

@Column(name = "USER_NAME", nullable = false, length = 75, updatable= false)
private String userName;

The updatable属性指示 Hibernate 从生成的数据中省略此列UPDATESQL 语句。

我删除了@Transient@Id注释。

如果此列是您的 PK(映射到实体标识符),那么您只能在 INSERT 期间设置它,因为 Hibernate 不允许您更新实体标识符(updatable在这种情况下属性是多余的)。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用 JPA 进行更新时如何排除实体字段 的相关文章

随机推荐