Spring Batch統合MyBatis、durid接続池互換MyBatis CurrsorItemReader存在bug、他の接続池を選択します.



import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.batch.MyBatisCursorItemReader;
import org.springframework.batch.core.Job;
import org.springframework.batch.core.JobParameter;
import org.springframework.batch.core.Step;
import org.springframework.batch.core.configuration.annotation.JobBuilderFactory;
import org.springframework.batch.core.configuration.annotation.StepBuilderFactory;
import org.springframework.batch.core.configuration.annotation.StepScope;
import org.springframework.batch.core.step.tasklet.TaskletStep;
import org.springframework.batch.item.ItemReader;
import org.springframework.batch.item.ItemStreamReader;
import org.springframework.batch.item.ItemWriter;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Scope;
import org.springframework.context.annotation.ScopedProxyMode;
import org.springframework.scheduling.annotation.EnableAsync;
import org.springframework.stereotype.Component;

import java.util.HashMap;
import java.util.Map;
import java.util.UUID;

/**
 * @ClassName readByMybatisJob
 * @Description:       mybtatis from reader
 * @Author 
 * @Date 2020/5/29 9:54
 * @Version V1.0
 **/
@Slf4j
@Component
public class ReadByMybatisJob {

    @Autowired
    private SqlSessionFactory sqlSessionFactory;

    @Autowired
    protected JobBuilderFactory jobBuilderFactory;

    @Autowired
    protected StepBuilderFactory stepBuilderFactory;

    @Bean
    @StepScope
    public ItemStreamReader myBatisCursorItemDemoReader(@Value("#{jobParameters[operationTypeId]}") String operationTypeId, @Value("#{jobParameters[messageType]}") String messageType) {
        MyBatisCursorItemReader reader = new MyBatisCursorItemReader();
        Map parameterValues = new HashMap<>();
        parameterValues.put("operationTypeId", operationTypeId);
        parameterValues.put("messageType", messageType);

        reader.setSqlSessionFactory(sqlSessionFactory);
        reader.setParameterValues(parameterValues);
        reader.setQueryId("*.mapper.BatchMessageFieldMapper.getBatchMessageFields");
        return reader;
    }


    /***
     *    demo
     * @methodName myBatisCursorItemWriter
     * @param
     * @return org.springframework.batch.item.ItemWriter
     * @author 
     * @date 2020/5/29 9:38
     * @throws
     */
    @Bean("myBatisCursorItemWriter")
    public ItemWriter myBatisCursorItemWriter() {
        CommonFileItemWriter commonFileItemWriter = new CommonFileItemWriter(BatchMessageField.class);
        return commonFileItemWriter;
    }


    /**
     *   Job
     *
     * @param jobBuilderFactory
     * @param myBatisCursorStep   
     * @return
     */
    @Bean("myBatisCursorDemoJob")
    public Job readJsonFileDemoJob(JobBuilderFactory jobBuilderFactory, Step myBatisCursorStep) {
        return jobBuilderFactory.get("myBatisCursorDemoJob")
                .incrementer(parameters -> {
                    Map parameterMap = parameters.getParameters();
                    parameterMap.put("key", new JobParameter(UUID.randomUUID().toString()));
                    return parameters;
                }).start(myBatisCursorStep).build();

    }


    /**
     * step   
     *
     * @param
     * @param myBatisCursorItemDemoReader  bean
     * @param myBatisCursorItemWriter      bean
     * @return
     */
    @Bean("myBatisCursorStep")
    public Step myBatisCursorStep( ItemReader myBatisCursorItemDemoReader, @Qualifier("myBatisCursorItemWriter") ItemWriter myBatisCursorItemWriter) {
       return  stepBuilderFactory.get("myBatisCursorStep")
                .chunk(1)
                .reader(myBatisCursorItemDemoReader)
                // .processor(processor)
                .writer(myBatisCursorItemWriter)
                .build();

    }


}