Spring Batch(6) : ItemReader & ItemWriter

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

针对批处理,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 
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值