Class MongoItemReader<T>
- All Implemented Interfaces:
- ItemReader<T>,- ItemStream,- ItemStreamReader<T>,- org.springframework.beans.factory.InitializingBean
 Restartable ItemReader that reads documents from MongoDB
 via a paging technique.
 
 If you set JSON String query setQuery(String) then
 it executes the JSON to retrieve the requested documents.
 
 If you set Query object setQuery(Query) then
 it executes the Query to retrieve the requested documents.
 
 The query is executed using paged requests specified in the
 AbstractPaginatedDataItemReader.setPageSize(int).  Additional pages are requested as needed to
 provide data when the AbstractItemCountingItemStreamItemReader.read() method is called.
 
The JSON String query provided supports parameter substitution via ?<index> placeholders where the <index> indicates the index of the parameterValue to substitute.
 The implementation is thread-safe between calls to
 AbstractItemCountingItemStreamItemReader.open(ExecutionContext), but remember to use saveState=false
 if used in a multi-threaded client (no restart available).
 
- Author:
- Michael Minella, Takaaki Iida, Mahmoud Ben Hassine, Parikshit Dutta
- 
Field SummaryFields inherited from class org.springframework.batch.item.data.AbstractPaginatedDataItemReaderpage, pageSize, results
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidChecks mandatory propertiesMethod thisItemStreamReaderdelegates to for the actual work of reading a page.voidsetCollection(String collection) voidJSON defining the fields to be returned from the matching documents by MongoDB.voidJSON String telling MongoDB what index to use.voidsetParameterValues(List<Object> parameterValues) Listof values to be substituted in for each of the parameters in the query.voidA JSON formatted MongoDB query.voidsetQuery(org.springframework.data.mongodb.core.query.Query query) A Mongo Query to be used.voidMapof property names/Sort.Directionvalues to sort the input by.voidsetTargetType(Class<? extends T> type) The type of object to be returned for eachAbstractItemCountingItemStreamItemReader.read()call.voidsetTemplate(org.springframework.data.mongodb.core.MongoOperations template) Used to perform operations against the MongoDB instance.Methods inherited from class org.springframework.batch.item.data.AbstractPaginatedDataItemReaderdoClose, doOpen, doRead, jumpToItem, setPageSizeMethods 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, setExecutionContextName, setName
- 
Constructor Details- 
MongoItemReaderpublic MongoItemReader()
 
- 
- 
Method Details- 
setQuerypublic void setQuery(org.springframework.data.mongodb.core.query.Query query) A Mongo Query to be used.- Parameters:
- query- Mongo Query to be used.
 
- 
setTemplatepublic void setTemplate(org.springframework.data.mongodb.core.MongoOperations template) Used to perform operations against the MongoDB instance. Also handles the mapping of documents to objects.- Parameters:
- template- the MongoOperations instance to use
- See Also:
- 
- MongoOperations
 
 
- 
setQueryA JSON formatted MongoDB query. Parameterization of the provided query is allowed via ?<index> placeholders where the <index> indicates the index of the parameterValue to substitute.- Parameters:
- queryString- JSON formatted Mongo query
 
- 
setTargetTypeThe type of object to be returned for eachAbstractItemCountingItemStreamItemReader.read()call.- Parameters:
- type- the type of object to return
 
- 
setParameterValuesListof values to be substituted in for each of the parameters in the query.- Parameters:
- parameterValues- values
 
- 
setFieldsJSON defining the fields to be returned from the matching documents by MongoDB.- Parameters:
- fields- JSON string that identifies the fields to sort by.
 
- 
setSortMapof property names/Sort.Directionvalues to sort the input by.- Parameters:
- sorts- map of properties and direction to sort each.
 
- 
setCollection- Parameters:
- collection- Mongo collection to be queried.
 
- 
setHintJSON String telling MongoDB what index to use.- Parameters:
- hint- string indicating what index to use.
 
- 
doPageReadDescription copied from class:AbstractPaginatedDataItemReaderMethod thisItemStreamReaderdelegates to for the actual work of reading a page. Each time this method is called, the resultingIteratorshould contain the items read within the next page.
 If theIteratoris empty or null when it is returned, thisItemReaderwill assume that the input has been exhausted.- Specified by:
- doPageReadin class- AbstractPaginatedDataItemReader<T>
- Returns:
- an Iteratorcontaining the items within a page.
 
- 
afterPropertiesSetChecks mandatory properties- Specified by:
- afterPropertiesSetin interface- org.springframework.beans.factory.InitializingBean
- Throws:
- Exception
- See Also:
- 
- InitializingBean.afterPropertiesSet()
 
 
 
-