我配置了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" />