使用JPA更新时如何排除实体字段
有没有一种方法可以使字段在使用JPA-Hibernate 4进行更新操作时不持久,但在创建操作时持久化?
我以这种方式尝试过
@Transient@Id
@Column(name = "USER_NAME", nullable = false, length = 75)
private String userName;
但是使用@Transient注释时,该字段将在所有CRUD操作中都是瞬态的,我想要一种方法来指定仅在此操作上是持久性的(创建)。
有没有办法做到这一点?
谢谢!
回答:
如本文所述,您需要设置updatable
为false
:
@Column(name = "USER_NAME", nullable = false, length = 75, updatable= false)private String userName;
该updatable
属性指示Hibernate从生成的UPDATE
SQL语句中忽略此列。
我删除了@Transient
和@Id
注释。
如果此列是您的PK(映射到实体标识符),则只能在INSERT期间进行设置,因为Hibernate不允许您更新实体标识符(updatable
在这种情况下该属性是多余的)。
以上是 使用JPA更新时如何排除实体字段 的全部内容, 来源链接: utcz.com/qa/433162.html