Class AbstractCursorItemReader<T>
- All Implemented Interfaces:
- ItemReader<T>,- ItemStream,- ItemStreamReader<T>,- org.springframework.beans.factory.InitializingBean
- Direct Known Subclasses:
- JdbcCursorItemReader,- StoredProcedureItemReader
Abstract base class for any simple item reader that opens a database cursor and continually retrieves the next row in the ResultSet.
By default the cursor will be opened using a separate connection. The ResultSet for the cursor is held open regardless of commits or roll backs in a surrounding transaction. Clients of this reader are responsible for buffering the items in the case that they need to be re-presented on a rollback. This buffering is handled by the step implementations provided and is only a concern for anyone writing their own step implementations.
 There is an option (setUseSharedExtendedConnection(boolean) that will share
 the connection used for the cursor with the rest of the step processing. If you set
 this flag to true then you must wrap the DataSource in a
 ExtendedConnectionDataSourceProxy to prevent the connection from being closed
 and released after each commit performed as part of the step processing. You must also
 use a JDBC driver supporting JDBC 3.0 or later since the cursor will be opened with the
 additional option of 'HOLD_CURSORS_OVER_COMMIT' enabled.
 
 Each call to AbstractItemCountingItemStreamItemReader.read() will attempt to map the row at the current position in the
 ResultSet. There is currently no wrapping of the ResultSet to suppress calls to next().
 However, if the RowMapper (mistakenly) increments the current row, the next call to
 read will verify that the current row is at the expected position and throw a
 DataAccessException if it is not. The reason for such strictness on the ResultSet is
 due to the need to maintain control for transactions and restartability. This ensures
 that each call to AbstractItemCountingItemStreamItemReader.read() returns the ResultSet at the correct row, regardless
 of rollbacks or restarts.
 
 ExecutionContext: The current row is returned as restart data, and when
 restored from that same data, the cursor is opened and the current row set to the value
 within the restart data. See setDriverSupportsAbsolute(boolean) for improving
 restart performance.
 
 Calling close on this ItemStream will cause all resources it is currently using
 to be freed. (Connection, ResultSet, etc). It is then illegal to call AbstractItemCountingItemStreamItemReader.read()
 again until it has been re-opened.
 
 Known limitation: when used with Derby setVerifyCursorPosition(boolean) needs
 to be false because ResultSet.getRow() call used for cursor
 position verification is not available for 'TYPE_FORWARD_ONLY' result sets.
 
Subclasses are inherently not thread-safe.
- Author:
- Lucas Ward, Peter Zozom, Robert Kasanicky, Thomas Risberg, Michael Minella, Mahmoud Ben Hassine
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected final org.apache.commons.logging.LogLogger available to subclassesprotected ResultSetstatic final int
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidAssert that mandatory properties are set.protected voidPrepare the given JDBC Statement (or PreparedStatement or CallableStatement), applying statement settings such as fetch size, max rows, and query timeout.protected abstract voidcleanupOnClose(Connection connection) Clean up resources.protected voiddoClose()Close the cursor and database connection.protected voiddoOpen()Execute the statement to open the cursor.protected TdoRead()Read next row and map it to item, verify cursor position ifsetVerifyCursorPosition(boolean)is true.Public getter for the data source.protected org.springframework.jdbc.support.SQLExceptionTranslatorCreates a default SQLErrorCodeSQLExceptionTranslator for the specified DataSource if none is set.abstract StringgetSql()protected voidhandleWarnings(Statement statement) Throw a SQLWarningException if we're not ignoring warnings, else log the warnings (at debug level).protected voidbooleanprotected voidjumpToItem(int itemIndex) UseResultSet.absolute(int)if possible, otherwise scroll by callingResultSet.next().protected abstract voidopenCursor(Connection con) protected abstract TreadCursor(ResultSet rs, int currentRow) Read the cursor and map to the type of object this reader should return.voidsetConnectionAutoCommit(boolean autoCommit) Set whether "autoCommit" should be overridden for the connection used by the cursor.voidsetDataSource(DataSource dataSource) Public setter for the data source for injection purposes.voidsetDriverSupportsAbsolute(boolean driverSupportsAbsolute) Indicate whether the JDBC driver supports setting the absolute row on aResultSet.voidsetFetchSize(int fetchSize) Gives the JDBC driver a hint as to the number of rows that should be fetched from the database when more rows are needed for thisResultSetobject.voidsetIgnoreWarnings(boolean ignoreWarnings) Set whether SQLWarnings should be ignored (only logged) or exception should be thrown.voidsetMaxRows(int maxRows) Sets the limit for the maximum number of rows that anyResultSetobject can contain to the given number.voidsetQueryTimeout(int queryTimeout) Sets the number of seconds the driver will wait for aStatementobject to execute to the given number of seconds.voidsetUseSharedExtendedConnection(boolean useSharedExtendedConnection) Indicate whether the connection used for the cursor should be used by all other processing thus sharing the same transaction.voidsetVerifyCursorPosition(boolean verifyCursorPosition) Allow verification of cursor position after current row is processed by RowMapper or RowCallbackHandler.protected org.springframework.dao.DataAccessExceptiontranslateSqlException(String task, String sql, SQLException ex) Methods inherited from class org.springframework.batch.item.support.AbstractItemCountingItemStreamItemReaderclose, getCurrentItemCount, isSaveState, open, read, setCurrentItemCount, setMaxItemCount, setSaveState, updateMethods inherited from class org.springframework.batch.item.ItemStreamSupportgetExecutionContextKey, getName, setExecutionContextName, setName
- 
Field Details- 
logprotected final org.apache.commons.logging.Log logLogger available to subclasses
- 
VALUE_NOT_SETpublic static final int VALUE_NOT_SET- See Also:
 
- 
rs
 
- 
- 
Constructor Details- 
AbstractCursorItemReaderpublic AbstractCursorItemReader()
 
- 
- 
Method Details- 
afterPropertiesSetAssert that mandatory properties are set.- Specified by:
- afterPropertiesSetin interface- org.springframework.beans.factory.InitializingBean
- Throws:
- IllegalArgumentException- if either data source or SQL properties not set.
- Exception
 
- 
setDataSourcePublic setter for the data source for injection purposes.- Parameters:
- dataSource-- DataSourceto be used
 
- 
getDataSourcePublic getter for the data source.- Returns:
- the dataSource
 
- 
applyStatementSettingsPrepare the given JDBC Statement (or PreparedStatement or CallableStatement), applying statement settings such as fetch size, max rows, and query timeout. @param stmt the JDBC Statement to prepare- Parameters:
- stmt-- PreparedStatementto be configured
- Throws:
- SQLException- if interactions with provided stmt fail
- See Also:
 
- 
getExceptionTranslatorprotected org.springframework.jdbc.support.SQLExceptionTranslator getExceptionTranslator()Creates a default SQLErrorCodeSQLExceptionTranslator for the specified DataSource if none is set.- Returns:
- the exception translator for this instance.
 
- 
translateSqlExceptionprotected org.springframework.dao.DataAccessException translateSqlException(String task, String sql, SQLException ex) 
- 
handleWarningsprotected void handleWarnings(Statement statement) throws org.springframework.jdbc.SQLWarningException, SQLException Throw a SQLWarningException if we're not ignoring warnings, else log the warnings (at debug level).- Parameters:
- statement- the current statement to obtain the warnings from, if there are any.
- Throws:
- SQLException- if interaction with provided statement fails.
- org.springframework.jdbc.SQLWarningException
- See Also:
- 
- SQLWarningException
 
 
- 
setFetchSizepublic void setFetchSize(int fetchSize) Gives the JDBC driver a hint as to the number of rows that should be fetched from the database when more rows are needed for thisResultSetobject. If the fetch size specified is zero, the JDBC driver ignores the value.- Parameters:
- fetchSize- the number of rows to fetch
- See Also:
 
- 
setMaxRowspublic void setMaxRows(int maxRows) Sets the limit for the maximum number of rows that anyResultSetobject can contain to the given number.- Parameters:
- maxRows- the new max rows limit; zero means there is no limit
- See Also:
 
- 
setQueryTimeoutpublic void setQueryTimeout(int queryTimeout) Sets the number of seconds the driver will wait for aStatementobject to execute to the given number of seconds. If the limit is exceeded, anSQLExceptionis thrown.- Parameters:
- queryTimeout- seconds the new query timeout limit in seconds; zero means there is no limit
- See Also:
 
- 
setIgnoreWarningspublic void setIgnoreWarnings(boolean ignoreWarnings) Set whether SQLWarnings should be ignored (only logged) or exception should be thrown.- Parameters:
- ignoreWarnings- if TRUE, warnings are ignored
 
- 
setVerifyCursorPositionpublic void setVerifyCursorPosition(boolean verifyCursorPosition) Allow verification of cursor position after current row is processed by RowMapper or RowCallbackHandler. Default value is TRUE.- Parameters:
- verifyCursorPosition- if true, cursor position is verified
 
- 
setDriverSupportsAbsolutepublic void setDriverSupportsAbsolute(boolean driverSupportsAbsolute) Indicate whether the JDBC driver supports setting the absolute row on aResultSet. It is recommended that this is set totruefor JDBC drivers that supports ResultSet.absolute() as it may improve performance, especially if a step fails while working with a large data set.- Parameters:
- driverSupportsAbsolute-- falseby default
- See Also:
 
- 
setConnectionAutoCommitpublic void setConnectionAutoCommit(boolean autoCommit) Set whether "autoCommit" should be overridden for the connection used by the cursor. If not set, defaults to Connection / Datasource default configuration.- Parameters:
- autoCommit- value used for- Connection.setAutoCommit(boolean).
- Since:
- 4.0
 
- 
getSql
- 
doCloseClose the cursor and database connection. Make call to cleanupOnClose so sub classes can cleanup any resources they have allocated.- Specified by:
- doClosein class- AbstractItemCountingItemStreamItemReader<T>
- Throws:
- Exception- Allows subclasses to throw checked exceptions for interpretation by the framework
 
- 
cleanupOnCloseClean up resources.- Parameters:
- connection- to the database
- Throws:
- Exception- If unable to clean up resources
 
- 
doOpenExecute the statement to open the cursor.- Specified by:
- doOpenin class- AbstractItemCountingItemStreamItemReader<T>
- Throws:
- Exception- Allows subclasses to throw checked exceptions for interpretation by the framework
 
- 
initializeConnectionprotected void initializeConnection()
- 
openCursor
- 
doReadRead next row and map it to item, verify cursor position ifsetVerifyCursorPosition(boolean)is true.- Specified by:
- doReadin class- AbstractItemCountingItemStreamItemReader<T>
- Returns:
- an item or nullif the data source is exhausted
- Throws:
- Exception- Allows subclasses to throw checked exceptions for interpretation by the framework
 
- 
readCursorRead the cursor and map to the type of object this reader should return. This method must be overridden by subclasses.- Parameters:
- rs- The current result set
- currentRow- Current position of the result set
- Returns:
- the mapped object at the cursor position
- Throws:
- SQLException- if interactions with the current result set fail
 
- 
jumpToItemUseResultSet.absolute(int)if possible, otherwise scroll by callingResultSet.next().- Overrides:
- jumpToItemin class- AbstractItemCountingItemStreamItemReader<T>
- Parameters:
- itemIndex- index of item (0 based) to jump to.
- Throws:
- Exception- Allows subclasses to throw checked exceptions for interpretation by the framework
 
 
-