aurelius aurelius - 7 days ago 11
Java Question

Exclude entity field at update with JPA

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

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).

Comments