How to exclude an entity field when doing an update with JPA

aurelius picture aurelius · Feb 6, 2015 · Viewed 13.8k times · Source

Is there a way to make a field non-persistent at update operation but persistent at create operation with JPA - Hibernate 4?

I tried it in this way

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

but with @Transient annotation the field will be transient across all CRUD operations and I want a way to specify that only on this operation is persistent (create).

Is there a way to do this?

Thanks!

Answer

Vlad Mihalcea picture Vlad Mihalcea · Feb 6, 2015

As explained in this article, you need to set updatable to false:

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

The updatable attribute instruct Hibernate to omit this column from the generated UPDATE SQL statement.

I removed the @Transient and the @Id annotations.

If this column is your PK (mapped to the entity identifier), then you can only set it during INSERT, since Hibernate doesn't allow you to update an entity identifier (the updatable attribute being redundant in this case).