针对批处理,Spring Batch提供ItemReader、ItemProcessor、ItemWriter三个核心组件,类似ETL的三个步骤。
5.1 ItemReader
ItemReader支持从多种数据源读入数据,接口定义如下:
public interface ItemReader<T> {
T read() throws Exception, UnexpectedInputException, ParseException;
}
泛型T表示读入的Item类型,一般是有明确意义的领域模型。通常情况下,read方法读入数据,返回item,如果没有更多数据,返回null。 在特殊的场景下,可以支持事务操作,例如对于JMS数据源,可以在事务回滚你的时候重新放回地队列中。
5.1.1 基于游标的Reader
在数据库解决方案中,游标是一个核心概念,JDBS的ResultSet也使用了Cursor的概念,如:
基于Cursor的Reader将游标的概念转化为流的概念,例如配置一个CursorReader:
<bean id="itemReader" class="org.spr...JdbcCursorItemReader">
<property name="dataSource" ref="dataSource"/>
<property name="sql" value="select ID, NAME, CREDIT from CUSTOMER"/>
<property name="rowMapper">
<bean class="org.springframework.batch.sample.domain.CustomerCreditRowMapper"/>
</property>
</bean>
调用该Reader的read方法将逐条返回结果中的item,而无需关心底层细节
5.1.2 基于存储过程的Reader
如果使用存储过程查询Item,则可以通过StoreProcedureItemReader完成,下面是一个简单例子:
<bean id="reader" class="o.s.batch.item.database.StoredProcedureItemReader">
<property name="dataSource" ref="dataSource"/>
<property name="procedureName" value="sp_customer_credit"/>
<property name="rowMapper">
<bean class="org.springframework.batch.sample.domain.CustomerCreditRowMapper"/>
</property>
</bean>
如果使用的是函数调用:
<bean id="reader" class="o.s.batch.item.database.StoredProcedureItemReader">
<property name="dataSource" ref="dataSource"/>
<property name="procedureName" value="sp_customer_credit"/>
<property name="function" value="true"/>
<property name="rowMapper">
<bean class="org.springframework.batch.sample.domain.CustomerCreditRowMapper"/>
</property>
</bean>
如果带有参数:
<bean id="reader" class="o.s.batch.item.database.StoredProcedureItemReader">
<property name="dataSource" ref="dataSource"/>
<property name="procedureName" value="spring.cursor_func"/>
<property name="parameters">
<list>
<bean class="org.springframework.jdbc.core.SqlOutParameter">
<constructor-arg index="0" value="newid"/>
<constructor-arg

本文详细介绍了Spring Batch中的核心组件ItemReader和ItemWriter,包括基于游标、存储过程、分页的Reader实现,以及如何通过Adapter复用服务。同时,讨论了ItemProcessor的作用,如组合Processor、过滤Item以及实现事务性。此外,还提到了输入校验的重要性及其在批处理中的应用。
最低0.47元/天 解锁文章
1828

被折叠的 条评论
为什么被折叠?



