In JPA, I am confused when to use the attribute optional=false
and the annotation @Column(nullable=false)
. What is the difference?
Both is used to prevent a null value, but if you mind that null should be blocked in ...
The database layer (and you want to generate the schema using JPA) --> use @Column(nullable=false)
The runtime (and before contacting the database)--> use optional=false
(much faster than the first checking).
If you want both abilities, use them both.
@Column(nullable=false)
is an instruction for generating the schema. The database column generated off the class will be marked not nullable in the actual database.
optional=false
is a runtime instruction. The primary functional thing it does is related to Lazy Loading. You can't lazy load a non-collection mapped entity unless you remember to set optional=false (because Hibernate doesn't know if there should be a proxy there or a null, unless you tell it nulls are impossible, so it can generate a proxy.)