public abstract class EntityManagerFactoryUtils
extends java.lang.Object
Mainly intended for internal use within the framework.
| Modifier and Type | Field and Description | 
|---|---|
| static int | ENTITY_MANAGER_SYNCHRONIZATION_ORDEROrder value for TransactionSynchronization objects that clean up JPA
 EntityManagers. | 
| Constructor and Description | 
|---|
| EntityManagerFactoryUtils() | 
| Modifier and Type | Method and Description | 
|---|---|
| static void | applyTransactionTimeout(Query query,
                       EntityManagerFactory emf)Apply the current transaction timeout, if any, to the given JPA Query object. | 
| static void | closeEntityManager(EntityManager em)Close the given JPA EntityManager,
 catching and logging any cleanup exceptions thrown. | 
| static DataAccessException | convertJpaAccessExceptionIfPossible(java.lang.RuntimeException ex)Convert the given runtime exception to an appropriate exception from the
  org.springframework.daohierarchy. | 
| static EntityManager | doGetTransactionalEntityManager(EntityManagerFactory emf,
                               java.util.Map<?,?> properties)Obtain a JPA EntityManager from the given factory. | 
| static EntityManager | doGetTransactionalEntityManager(EntityManagerFactory emf,
                               java.util.Map<?,?> properties,
                               boolean synchronizedWithTransaction)Obtain a JPA EntityManager from the given factory. | 
| static EntityManagerFactory | findEntityManagerFactory(ListableBeanFactory beanFactory,
                        java.lang.String unitName)Find an EntityManagerFactory with the given name in the given
 Spring application context (represented as ListableBeanFactory). | 
| static EntityManager | getTransactionalEntityManager(EntityManagerFactory emf)Obtain a JPA EntityManager from the given factory. | 
| static EntityManager | getTransactionalEntityManager(EntityManagerFactory emf,
                             java.util.Map<?,?> properties)Obtain a JPA EntityManager from the given factory. | 
public static final int ENTITY_MANAGER_SYNCHRONIZATION_ORDER
public static EntityManagerFactory findEntityManagerFactory(ListableBeanFactory beanFactory, @Nullable java.lang.String unitName) throws NoSuchBeanDefinitionException
The specified unit name will be matched against the configured
 persistence unit, provided that a discovered EntityManagerFactory
 implements the EntityManagerFactoryInfo interface. If not,
 the persistence unit name will be matched against the Spring bean name,
 assuming that the EntityManagerFactory bean names follow that convention.
 
If no unit name has been given, this method will search for a default
 EntityManagerFactory through BeanFactory.getBean(Class).
beanFactory - the ListableBeanFactory to searchunitName - the name of the persistence unit (may be null or empty,
 in which case a single bean of type EntityManagerFactory will be searched for)NoSuchBeanDefinitionException - if there is no such EntityManagerFactory in the contextEntityManagerFactoryInfo.getPersistenceUnitName()@Nullable public static EntityManager getTransactionalEntityManager(EntityManagerFactory emf) throws DataAccessResourceFailureException
Note: Will return null if no thread-bound EntityManager found!
emf - the EntityManagerFactory to create the EntityManager withnull if none foundDataAccessResourceFailureException - if the EntityManager couldn't be obtainedJpaTransactionManager@Nullable public static EntityManager getTransactionalEntityManager(EntityManagerFactory emf, @Nullable java.util.Map<?,?> properties) throws DataAccessResourceFailureException
Note: Will return null if no thread-bound EntityManager found!
emf - the EntityManagerFactory to create the EntityManager withproperties - the properties to be passed into the createEntityManager
 call (may be null)null if none foundDataAccessResourceFailureException - if the EntityManager couldn't be obtainedJpaTransactionManager@Nullable public static EntityManager doGetTransactionalEntityManager(EntityManagerFactory emf, java.util.Map<?,?> properties) throws PersistenceException
Same as getEntityManager, but throwing the original PersistenceException.
emf - the EntityManagerFactory to create the EntityManager withproperties - the properties to be passed into the createEntityManager
 call (may be null)null if none foundPersistenceException - if the EntityManager couldn't be createdgetTransactionalEntityManager(javax.persistence.EntityManagerFactory), 
JpaTransactionManager@Nullable public static EntityManager doGetTransactionalEntityManager(EntityManagerFactory emf, @Nullable java.util.Map<?,?> properties, boolean synchronizedWithTransaction) throws PersistenceException
Same as getEntityManager, but throwing the original PersistenceException.
emf - the EntityManagerFactory to create the EntityManager withproperties - the properties to be passed into the createEntityManager
 call (may be null)synchronizedWithTransaction - whether to automatically join ongoing
 transactions (according to the JPA 2.1 SynchronizationType rules)null if none foundPersistenceException - if the EntityManager couldn't be createdgetTransactionalEntityManager(javax.persistence.EntityManagerFactory), 
JpaTransactionManagerpublic static void applyTransactionTimeout(Query query, EntityManagerFactory emf)
This method sets the JPA 2.0 query hint "javax.persistence.query.timeout" accordingly.
query - the JPA Query objectemf - the JPA EntityManagerFactory that the Query was created for@Nullable public static DataAccessException convertJpaAccessExceptionIfPossible(java.lang.RuntimeException ex)
org.springframework.dao hierarchy.
 Return null if no translation is appropriate: any other exception may
 have resulted from user code, and should not be translated.
 The most important cases like object not found or optimistic locking failure are covered here. For more fine-granular conversion, JpaTransactionManager etc support sophisticated translation of exceptions via a JpaDialect.
ex - runtime exception that occurrednull if the exception should not be translatedpublic static void closeEntityManager(@Nullable EntityManager em)
em - the JPA EntityManager to close (may be null)EntityManager.close()