public class LocalSessionFactoryBean extends HibernateExceptionTranslator implements FactoryBean<SessionFactory>, ResourceLoaderAware, InitializingBean, DisposableBean
FactoryBean
that creates a Hibernate
SessionFactory
. This is the usual way to set up a shared
Hibernate SessionFactory in a Spring application context; the SessionFactory can
then be passed to Hibernate-based data access objects via dependency injection.
Compatible with Hibernate 5.0/5.1 as well as 5.2, as of Spring 4.3.
setDataSource(javax.sql.DataSource)
,
setPackagesToScan(java.lang.String...)
,
LocalSessionFactoryBuilder
Modifier and Type | Field and Description |
---|---|
private java.lang.Class<?>[] |
annotatedClasses |
private java.lang.String[] |
annotatedPackages |
private AsyncTaskExecutor |
bootstrapExecutor |
private Resource[] |
cacheableMappingLocations |
private Resource[] |
configLocations |
private Configuration |
configuration |
private CurrentTenantIdentifierResolver |
currentTenantIdentifierResolver |
private javax.sql.DataSource |
dataSource |
private Interceptor |
entityInterceptor |
private TypeFilter[] |
entityTypeFilters |
private java.util.Properties |
hibernateProperties |
private ImplicitNamingStrategy |
implicitNamingStrategy |
private java.lang.Object |
jtaTransactionManager |
private Resource[] |
mappingDirectoryLocations |
private Resource[] |
mappingJarLocations |
private Resource[] |
mappingLocations |
private java.lang.String[] |
mappingResources |
private MetadataSources |
metadataSources |
private boolean |
metadataSourcesAccessed |
private MultiTenantConnectionProvider |
multiTenantConnectionProvider |
private java.lang.String[] |
packagesToScan |
private PhysicalNamingStrategy |
physicalNamingStrategy |
private ResourcePatternResolver |
resourcePatternResolver |
private SessionFactory |
sessionFactory |
Constructor and Description |
---|
LocalSessionFactoryBean() |
Modifier and Type | Method and Description |
---|---|
void |
afterPropertiesSet()
Invoked by a BeanFactory after it has set all bean properties supplied
(and satisfied BeanFactoryAware and ApplicationContextAware).
|
protected SessionFactory |
buildSessionFactory(LocalSessionFactoryBuilder sfb)
Subclasses can override this method to perform custom initialization
of the SessionFactory instance, creating it via the given Configuration
object that got prepared by this LocalSessionFactoryBean.
|
void |
destroy()
Invoked by a BeanFactory on destruction of a singleton.
|
Configuration |
getConfiguration()
Return the Hibernate Configuration object used to build the SessionFactory.
|
java.util.Properties |
getHibernateProperties()
Return the Hibernate properties, if any.
|
MetadataSources |
getMetadataSources()
Determine the Hibernate
MetadataSources to use. |
SessionFactory |
getObject()
Return an instance (possibly shared or independent) of the object
managed by this factory.
|
java.lang.Class<?> |
getObjectType()
Return the type of object that this FactoryBean creates,
or
null if not known in advance. |
ResourceLoader |
getResourceLoader()
Determine the Spring
ResourceLoader to use for Hibernate metadata. |
boolean |
isSingleton()
Is the object managed by this factory a singleton? That is,
will
FactoryBean.getObject() always return the same object
(a reference that can be cached)? |
void |
setAnnotatedClasses(java.lang.Class<?>... annotatedClasses)
Specify annotated entity classes to register with this Hibernate SessionFactory.
|
void |
setAnnotatedPackages(java.lang.String... annotatedPackages)
Specify the names of annotated packages, for which package-level
annotation metadata will be read.
|
void |
setBootstrapExecutor(AsyncTaskExecutor bootstrapExecutor)
Specify an asynchronous executor for background bootstrapping,
e.g.
|
void |
setCacheableMappingLocations(Resource... cacheableMappingLocations)
Set locations of cacheable Hibernate mapping files, for example as web app
resource "/WEB-INF/mapping/example.hbm.xml".
|
void |
setConfigLocation(Resource configLocation)
Set the location of a single Hibernate XML config file, for example as
classpath resource "classpath:hibernate.cfg.xml".
|
void |
setConfigLocations(Resource... configLocations)
Set the locations of multiple Hibernate XML config files, for example as
classpath resources "classpath:hibernate.cfg.xml,classpath:extension.cfg.xml".
|
void |
setCurrentTenantIdentifierResolver(CurrentTenantIdentifierResolver currentTenantIdentifierResolver)
Set a
CurrentTenantIdentifierResolver to be passed on to the SessionFactory. |
void |
setDataSource(javax.sql.DataSource dataSource)
Set the DataSource to be used by the SessionFactory.
|
void |
setEntityInterceptor(Interceptor entityInterceptor)
Set a Hibernate entity interceptor that allows to inspect and change
property values before writing to and reading from the database.
|
void |
setEntityTypeFilters(TypeFilter... entityTypeFilters)
Specify custom type filters for Spring-based scanning for entity classes.
|
void |
setHibernateProperties(java.util.Properties hibernateProperties)
Set Hibernate properties, such as "hibernate.dialect".
|
void |
setImplicitNamingStrategy(ImplicitNamingStrategy implicitNamingStrategy)
Set a Hibernate 5.0 ImplicitNamingStrategy for the SessionFactory.
|
void |
setJtaTransactionManager(java.lang.Object jtaTransactionManager)
Set the Spring
JtaTransactionManager
or the JTA javax.transaction.TransactionManager to be used with Hibernate,
if any. |
void |
setMappingDirectoryLocations(Resource... mappingDirectoryLocations)
Set locations of directories that contain Hibernate mapping resources,
like "WEB-INF/mappings".
|
void |
setMappingJarLocations(Resource... mappingJarLocations)
Set locations of jar files that contain Hibernate mapping resources,
like "WEB-INF/lib/example.hbm.jar".
|
void |
setMappingLocations(Resource... mappingLocations)
Set locations of Hibernate mapping files, for example as classpath
resource "classpath:example.hbm.xml".
|
void |
setMappingResources(java.lang.String... mappingResources)
Set Hibernate mapping resources to be found in the class path,
like "example.hbm.xml" or "mypackage/example.hbm.xml".
|
void |
setMetadataSources(MetadataSources metadataSources)
Specify a Hibernate
MetadataSources service to use (e.g. |
void |
setMultiTenantConnectionProvider(MultiTenantConnectionProvider multiTenantConnectionProvider)
Set a
MultiTenantConnectionProvider to be passed on to the SessionFactory. |
void |
setPackagesToScan(java.lang.String... packagesToScan)
Specify packages to search for autodetection of your entity classes in the
classpath.
|
void |
setPhysicalNamingStrategy(PhysicalNamingStrategy physicalNamingStrategy)
Set a Hibernate 5.0 PhysicalNamingStrategy for the SessionFactory.
|
void |
setResourceLoader(ResourceLoader resourceLoader)
Specify a Spring
ResourceLoader to use for Hibernate metadata. |
convertHibernateAccessException, translateExceptionIfPossible
private javax.sql.DataSource dataSource
private Resource[] configLocations
private java.lang.String[] mappingResources
private Resource[] mappingLocations
private Resource[] cacheableMappingLocations
private Resource[] mappingJarLocations
private Resource[] mappingDirectoryLocations
private Interceptor entityInterceptor
private ImplicitNamingStrategy implicitNamingStrategy
private PhysicalNamingStrategy physicalNamingStrategy
private java.lang.Object jtaTransactionManager
private MultiTenantConnectionProvider multiTenantConnectionProvider
private CurrentTenantIdentifierResolver currentTenantIdentifierResolver
private TypeFilter[] entityTypeFilters
private java.util.Properties hibernateProperties
private java.lang.Class<?>[] annotatedClasses
private java.lang.String[] annotatedPackages
private java.lang.String[] packagesToScan
private AsyncTaskExecutor bootstrapExecutor
private boolean metadataSourcesAccessed
private MetadataSources metadataSources
private ResourcePatternResolver resourcePatternResolver
private Configuration configuration
private SessionFactory sessionFactory
public void setDataSource(javax.sql.DataSource dataSource)
If this is set, the Hibernate settings should not define a connection provider to avoid meaningless double configuration.
public void setConfigLocation(Resource configLocation)
Note: Can be omitted when all necessary properties and mapping resources are specified locally via this bean.
Configuration#configure(java.net.URL)
public void setConfigLocations(Resource... configLocations)
Note: Can be omitted when all necessary properties and mapping resources are specified locally via this bean.
Configuration#configure(java.net.URL)
public void setMappingResources(java.lang.String... mappingResources)
Can be used to add to mappings from a Hibernate XML config file, or to specify all mappings locally.
setMappingLocations(org.springframework.core.io.Resource...)
,
Configuration#addResource
public void setMappingLocations(Resource... mappingLocations)
Can be used to add to mappings from a Hibernate XML config file, or to specify all mappings locally.
Configuration#addInputStream
public void setCacheableMappingLocations(Resource... cacheableMappingLocations)
Can be used to add to mappings from a Hibernate XML config file, or to specify all mappings locally.
Configuration#addCacheableFile(File)
public void setMappingJarLocations(Resource... mappingJarLocations)
Can be used to add to mappings from a Hibernate XML config file, or to specify all mappings locally.
Configuration#addJar(File)
public void setMappingDirectoryLocations(Resource... mappingDirectoryLocations)
Can be used to add to mappings from a Hibernate XML config file, or to specify all mappings locally.
Configuration#addDirectory(File)
public void setEntityInterceptor(Interceptor entityInterceptor)
Configuration#setInterceptor
public void setImplicitNamingStrategy(ImplicitNamingStrategy implicitNamingStrategy)
Configuration#setImplicitNamingStrategy
public void setPhysicalNamingStrategy(PhysicalNamingStrategy physicalNamingStrategy)
Configuration#setPhysicalNamingStrategy
public void setJtaTransactionManager(java.lang.Object jtaTransactionManager)
JtaTransactionManager
or the JTA javax.transaction.TransactionManager
to be used with Hibernate,
if any. Implicitly sets up JtaPlatform
.public void setMultiTenantConnectionProvider(MultiTenantConnectionProvider multiTenantConnectionProvider)
MultiTenantConnectionProvider
to be passed on to the SessionFactory.public void setCurrentTenantIdentifierResolver(CurrentTenantIdentifierResolver currentTenantIdentifierResolver)
CurrentTenantIdentifierResolver
to be passed on to the SessionFactory.public void setEntityTypeFilters(TypeFilter... entityTypeFilters)
Default is to search all specified packages for classes annotated with
@javax.persistence.Entity
, @javax.persistence.Embeddable
or @javax.persistence.MappedSuperclass
.
setPackagesToScan(java.lang.String...)
public void setHibernateProperties(java.util.Properties hibernateProperties)
Note: Do not specify a transaction provider here when using Spring-driven transactions. It is also advisable to omit connection provider settings and use a Spring-set DataSource instead.
setDataSource(javax.sql.DataSource)
public java.util.Properties getHibernateProperties()
public void setAnnotatedClasses(java.lang.Class<?>... annotatedClasses)
Configuration#addAnnotatedClass(Class)
public void setAnnotatedPackages(java.lang.String... annotatedPackages)
Configuration#addPackage(String)
public void setPackagesToScan(java.lang.String... packagesToScan)
ClassPathBeanDefinitionScanner
).public void setBootstrapExecutor(AsyncTaskExecutor bootstrapExecutor)
SimpleAsyncTaskExecutor
.
SessionFactory
initialization will then switch into background
bootstrap mode, with a SessionFactory
proxy immediately returned for
injection purposes instead of waiting for Hibernate's bootstrapping to complete.
However, note that the first actual call to a SessionFactory
method will
then block until Hibernate's bootstrapping completed, if not ready by then.
For maximum benefit, make sure to avoid early SessionFactory
calls
in init methods of related beans, even for metadata introspection purposes.
LocalSessionFactoryBuilder.buildSessionFactory(AsyncTaskExecutor)
public void setMetadataSources(MetadataSources metadataSources)
MetadataSources
service to use (e.g. reusing an
existing one), potentially populated with a custom Hibernate bootstrap
org.hibernate.service.ServiceRegistry
as well.public MetadataSources getMetadataSources()
MetadataSources
to use.
Can also be externally called to initialize and pre-populate a MetadataSources
instance which is then going to be used for SessionFactory
building.
null
)LocalSessionFactoryBuilder.LocalSessionFactoryBuilder(DataSource, ResourceLoader, MetadataSources)
public void setResourceLoader(ResourceLoader resourceLoader)
ResourceLoader
to use for Hibernate metadata.setResourceLoader
in interface ResourceLoaderAware
resourceLoader
- the ResourceLoader to use (never null
)ResourcePatternResolver
,
ResourcePatternUtils.getResourcePatternResolver(org.springframework.core.io.ResourceLoader)
public ResourceLoader getResourceLoader()
ResourceLoader
to use for Hibernate metadata.null
)public void afterPropertiesSet() throws java.io.IOException
InitializingBean
This method allows the bean instance to perform initialization only possible when all bean properties have been set and to throw an exception in the event of misconfiguration.
afterPropertiesSet
in interface InitializingBean
java.io.IOException
protected SessionFactory buildSessionFactory(LocalSessionFactoryBuilder sfb)
The default implementation invokes LocalSessionFactoryBuilder's buildSessionFactory. A custom implementation could prepare the instance in a specific way (e.g. applying a custom ServiceRegistry) or use a custom SessionFactoryImpl subclass.
sfb
- LocalSessionFactoryBuilder prepared by this LocalSessionFactoryBeanLocalSessionFactoryBuilder.buildSessionFactory(org.springframework.core.task.AsyncTaskExecutor)
public final Configuration getConfiguration()
java.lang.IllegalStateException
- if the Configuration object has not been initialized yetpublic SessionFactory getObject()
FactoryBean
As with a BeanFactory
, this allows support for both the
Singleton and Prototype design pattern.
If this FactoryBean is not fully initialized yet at the time of
the call (for example because it is involved in a circular reference),
throw a corresponding FactoryBeanNotInitializedException
.
As of Spring 2.0, FactoryBeans are allowed to return null
objects. The factory will consider this as normal value to be used; it
will not throw a FactoryBeanNotInitializedException in this case anymore.
FactoryBean implementations are encouraged to throw
FactoryBeanNotInitializedException themselves now, as appropriate.
getObject
in interface FactoryBean<SessionFactory>
null
)FactoryBeanNotInitializedException
public java.lang.Class<?> getObjectType()
FactoryBean
null
if not known in advance.
This allows one to check for specific types of beans without instantiating objects, for example on autowiring.
In the case of implementations that are creating a singleton object, this method should try to avoid singleton creation as far as possible; it should rather estimate the type in advance. For prototypes, returning a meaningful type here is advisable too.
This method can be called before this FactoryBean has been fully initialized. It must not rely on state created during initialization; of course, it can still use such state if available.
NOTE: Autowiring will simply ignore FactoryBeans that return
null
here. Therefore it is highly recommended to implement
this method properly, using the current state of the FactoryBean.
getObjectType
in interface FactoryBean<SessionFactory>
null
if not known at the time of the callListableBeanFactory.getBeansOfType(java.lang.Class<T>)
public boolean isSingleton()
FactoryBean
FactoryBean.getObject()
always return the same object
(a reference that can be cached)?
NOTE: If a FactoryBean indicates to hold a singleton object,
the object returned from getObject()
might get cached
by the owning BeanFactory. Hence, do not return true
unless the FactoryBean always exposes the same reference.
The singleton status of the FactoryBean itself will generally be provided by the owning BeanFactory; usually, it has to be defined as singleton there.
NOTE: This method returning false
does not
necessarily indicate that returned objects are independent instances.
An implementation of the extended SmartFactoryBean
interface
may explicitly indicate independent instances through its
SmartFactoryBean.isPrototype()
method. Plain FactoryBean
implementations which do not implement this extended interface are
simply assumed to always return independent instances if the
isSingleton()
implementation returns false
.
The default implementation returns true
, since a
FactoryBean
typically manages a singleton instance.
isSingleton
in interface FactoryBean<SessionFactory>
FactoryBean.getObject()
,
SmartFactoryBean.isPrototype()
public void destroy()
DisposableBean
destroy
in interface DisposableBean