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

aur*_*ius 6 java database hibernate jpa hibernate-mapping

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

我用这种方式试了一下

@Transient
@Id
@Column(name = "USER_NAME", nullable = false, length = 75)
private String userName;
Run Code Online (Sandbox Code Playgroud)

但是对于@Transient注释,该字段在所有CRUD操作中都是瞬态的,我想要一种方法来指定只有在此操作上才是持久的(创建).

有没有办法做到这一点?

谢谢!

Vla*_*cea 22

本文所述,您需要设置updatablefalse:

@Column(name = "USER_NAME", nullable = false, length = 75, updatable= false)
private String userName;
Run Code Online (Sandbox Code Playgroud)

updatable属性指示Hibernate从生成的UPDATESQL语句中省略该列.

我删除了@Transient@Id注释.

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