public class HibernateCursorItemReader<T> extends AbstractItemCountingItemStreamItemReader<T> implements org.springframework.beans.factory.InitializingBean
ItemStreamReader
for reading database records built on top of Hibernate. It
executes the HQL query when initialized iterates over the result set as
AbstractItemCountingItemStreamItemReader.read()
method is called, returning an object corresponding to
current row. The query can be set directly using
setQueryString(String)
, a named query can be used by
setQueryName(String)
, or a query provider strategy can be supplied
via setQueryProvider(HibernateQueryProvider)
.
The reader can be configured to use either StatelessSession
sufficient for simple mappings without the need to cascade to associated
objects or standard hibernate Session
for more advanced mappings or
when caching is desired. When stateful session is used it will be cleared in
the update(ExecutionContext)
method without being flushed (no data
modifications are expected).
Constructor and Description |
---|
HibernateCursorItemReader() |
Modifier and Type | Method and Description |
---|---|
void |
afterPropertiesSet() |
protected void |
doClose()
Close the cursor and hibernate session.
|
protected void |
doOpen()
Open hibernate session and create a forward-only cursor for the query.
|
protected T |
doRead()
Read next item from input.
|
protected void |
jumpToItem(int itemIndex)
Wind forward through the result set to the item requested.
|
void |
setFetchSize(int fetchSize)
Fetch size used internally by Hibernate to limit amount of data fetched
from database per round trip.
|
void |
setParameterValues(java.util.Map<java.lang.String,java.lang.Object> parameterValues)
The parameter values to apply to a query (map of name:value).
|
void |
setQueryName(java.lang.String queryName)
A query name for an externalized query.
|
void |
setQueryProvider(HibernateQueryProvider<T> queryProvider)
A query provider.
|
void |
setQueryString(java.lang.String queryString)
A query string in HQL.
|
void |
setSessionFactory(org.hibernate.SessionFactory sessionFactory)
The Hibernate SessionFactory to use the create a session.
|
void |
setUseStatelessSession(boolean useStatelessSession)
Can be set only in uninitialized state.
|
void |
update(ExecutionContext executionContext)
Update the context and clear the session if stateful.
|
close, getCurrentItemCount, isSaveState, open, read, setCurrentItemCount, setMaxItemCount, setSaveState
getExecutionContextKey, setExecutionContextName, setName
public void afterPropertiesSet() throws java.lang.Exception
afterPropertiesSet
in interface org.springframework.beans.factory.InitializingBean
java.lang.Exception
public void setParameterValues(java.util.Map<java.lang.String,java.lang.Object> parameterValues)
parameterValues
- the parameter values to setpublic void setQueryName(java.lang.String queryName)
query string
or the {
query provider
should
be set.queryName
- name of a hibernate named querypublic void setFetchSize(int fetchSize)
fetchSize
- the fetch size to pass down to Hibernatepublic void setQueryProvider(HibernateQueryProvider<T> queryProvider)
query string
or the {query name
should be
set.queryProvider
- Hibernate query providerpublic void setQueryString(java.lang.String queryString)
query provider
or the {
query name
should be set.queryString
- HQL query stringpublic void setSessionFactory(org.hibernate.SessionFactory sessionFactory)
sessionFactory
- the SessionFactory
to setpublic void setUseStatelessSession(boolean useStatelessSession)
useStatelessSession
- true
to use
StatelessSession
false
to use standard hibernate
Session
@Nullable protected T doRead() throws java.lang.Exception
AbstractItemCountingItemStreamItemReader
doRead
in class AbstractItemCountingItemStreamItemReader<T>
null
if the data source is exhaustedjava.lang.Exception
- Allows subclasses to throw checked exceptions for interpretation by the frameworkprotected void doOpen() throws java.lang.Exception
doOpen
in class AbstractItemCountingItemStreamItemReader<T>
java.lang.Exception
- Allows subclasses to throw checked exceptions for interpretation by the frameworkpublic void update(ExecutionContext executionContext) throws ItemStreamException
update
in interface ItemStream
update
in class AbstractItemCountingItemStreamItemReader<T>
executionContext
- the current ExecutionContext
ItemStreamException
- if there is a problemItemStream.update(ExecutionContext)
protected void jumpToItem(int itemIndex) throws java.lang.Exception
jumpToItem
in class AbstractItemCountingItemStreamItemReader<T>
itemIndex
- the first item to readjava.lang.Exception
- if there is a problemAbstractItemCountingItemStreamItemReader.jumpToItem(int)
protected void doClose() throws java.lang.Exception
doClose
in class AbstractItemCountingItemStreamItemReader<T>
java.lang.Exception
- Allows subclasses to throw checked exceptions for interpretation by the framework