我配置了Spring Batch作业,该作业从数据库中读取了一些项目,进行了一些基本处理,结果应创建csv文件:

<batch:job id="testJob" job-repository="jobRepository" parent="jobParent">
    <batch:step id="testStep" allow-start-if-complete="true">
        <batch:tasklet>
            <batch:chunk
                    reader="testReader"
                    processor="testProcessor"
                    writer="testFileItemWriter"
                    commit-interval="1"
            />
        </batch:tasklet>
    </batch:step>
</batch:job>

<bean id="testReader" ...>

<bean id="testProcessor" ...>

<bean id="testFileItemWriter" class="org.springframework.batch.item.file.FlatFileItemWriter" scope="step">
    <property name="resource" value="file:test.csv" />
    <property name="lineAggregator">
        <bean class="org.springframework.batch.item.file.transform.DelimitedLineAggregator">
            <property name="delimiter" value=", "/>
            <property name="fieldExtractor">
                <bean class="org.springframework.batch.item.file.transform.BeanWrapperFieldExtractor">
                    <property name="names" value="testId, firstName, lastName, addressLine1, addressLine2, city, stateProvince, postalCode,
                    country" />
                </bean>
            </property>
        </bean>
    </property>
</bean>


但是,即使读者从数据库0项中获取,也会创建此CSV文件。
因此,结果是创建了空的CSV文件。

当读取器在数据库中找不到任何项然后不创建空文件(不是调用写入器)时,我该怎么做?

最佳答案

在您的作家中,请添加以下属性,如果由作家创建,这将删除一个空文件。

<property name="shouldDeleteIfEmpty" value="true" />

09-03 20:31