使用 JPA 进行更新时如何排除实体字段
How to exclude an entity field when doing an update with JPA
有没有办法让字段在更新操作时非持久化,但在使用 JPA - Hibernate 4 创建操作时持久化?
我这样试过
@Transient
@Id
@Column(name = "USER_NAME", nullable = false, length = 75)
private String userName;
但是使用@Transient 注释,该字段在所有 CRUD 操作中都是瞬态的,我想要一种方法来指定仅在此操作上是持久的(创建)。
有办法吗?
谢谢!
您需要将 @Column
注释的 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 - Hibernate 4 创建操作时持久化?
我这样试过
@Transient
@Id
@Column(name = "USER_NAME", nullable = false, length = 75)
private String userName;
但是使用@Transient 注释,该字段在所有 CRUD 操作中都是瞬态的,我想要一种方法来指定仅在此操作上是持久的(创建)。
有办法吗?
谢谢!
您需要将 @Column
注释的 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
属性是多余的在这种情况下)。