3

我希望我的 Spring 批处理应用程序一次从数据库中读取 50 条记录,然后将这 50 条记录发送到处理器,然后发送到写入器。

有人可以告诉我如何做到这一点。

我尝试使用 JdbcPagingItemReader 并将 pageSize 设置为 50,它读取 50 条记录,但 rowMapper、处理器和写入器一次接收一条记录,而不是获取 50 条记录。

如何使处理器和编写器在 dto 中获得 50 条记录,而不是一次接收一条记录?

xml弹簧配置

<job id="indexJob" job-repository="jobRepository">
    <step id="job1">
        <tasklet transaction-manager="transactionManager">
            <chunk reader="reader" processor="processor" writer="writer" commit-interval="1"/>
        </tasklet>
    </step>
</job>

Java 弹簧配置

@Bean
@Scope("step")
public JdbcPagingItemReader reader() throws Exception {

    MySqlPagingQueryProvider provider = new MySqlPagingQueryProvider();
    provider.setSelectClause("select id");
    provider.setFromClause("from BATCH_CUSTOMER");
    provider.setSortKey("id");

    JdbcPagingItemReader reader = new JdbcPagingItemReader();
    reader.setDataSource(this.dataSource());
    reader.setQueryProvider(provider);
    reader.setPageSize(50);
    reader.setRowMapper(new MyRowMapper());
    reader.afterPropertiesSet();

    int counter = 0;
    ExecutionContext executionContext = new ExecutionContext();
    reader.open(executionContext);
    Object pageCredit = new Object();
    while (pageCredit != null) {
        pageCredit = reader.read();
        System.out.println("pageCredit:" + pageCredit);
        counter++;
    }
    reader.close();

    return reader;
}
4

2 回答 2

4

在您的 xml 配置中,将提交间隔更改为 50。

于 2013-04-08T15:36:30.880 回答
0

在 Spring 批处理论坛中回答

http://forum.springsource.org/showthread.php?136209-JdbcPagingItemReader-not-passing-all-page-records-to-the-processor&p=442538#post442538

这完全是您想要处理每条记录的设计。ItemWriter 获得尽可能多的记录,但受提交间隔的约束。你的是 1,这意味着每条记录都是单独提交的,我建议你将它设置为 50。处理器自己处理每条记录,直到达到提交间隔,然后调用 writer。如前所述,您的是1。

于 2013-04-09T12:28:34.953 回答