264 words
lock(entity, lockMode) - JPA EntityManager's method
Methodjavax.persistence.EntityManager
void lock(
Object entity,
LockModeType lockMode
)
Lock an entity instance that is contained in the persistence
context with the specified lock mode type.
If a pessimistic lock mode type is specified and the entity
contains a version attribute, the persistence provider must
also perform optimistic version checks when obtaining the
database lock. If these checks fail, the
OptimisticLockException will be thrown.
If the lock mode type is pessimistic and the entity instance is found but cannot be locked:
- the
PessimisticLockExceptionwill be thrown if the database locking failure causes transaction-level rollback - the
LockTimeoutExceptionwill be thrown if the database locking failure causes only statement-level rollback
- Parameters:
entity- entity instancelockMode- lock mode
- Throws:
IllegalArgumentException- if the instance is not an entity or is a detached entityTransactionRequiredException- if there is no transactionEntityNotFoundException- if the entity does not exist in the database when pessimistic locking is performedOptimisticLockException- if the optimistic version check failsPessimisticLockException- if pessimistic locking fails and the transaction is rolled backLockTimeoutException- if pessimistic locking fails and only the statement is rolled backPersistenceException- if an unsupported lock call is made
- Since:
- JPA 1.0
This documentation page is derived (with some adjustments) from the open source JPA 2 RI (EclipseLink)
and is available under the terms of the Eclipse Public License, v. 1.0 and Eclipse Distribution License, v. 1.0.
and is available under the terms of the Eclipse Public License, v. 1.0 and Eclipse Distribution License, v. 1.0.
Object Relational Mapping (ORM) JPA 2 providers include Hibernate, EclipseLink, TopLink, OpenJPA and DataNucleus.
Object DB is not an ORM JPA implementation but an Object Database for Java with built in JPA 2 support.