Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Spring Batch - more than one writer based on field value

I am working on spring batch, for writer currently using FlatFileItemWriter.

I would like to write my input file content to more than one flat file based on some field value. Is Spring batch support any kind of functionality by default.[something similar to CompositeItemWriter]

For example, my input file content is something like this.

john,35,retail,10000
joe,34,homeloan,20000
Amy,23,retail,2000

Now i would like to write two different files based on third column, it means row 1 and row 3 should go to file1 and row 2 should go to file2.

My writer configuration is:

<bean id="fileWriter" class="org.springframework.batch.item.file.FlatFileItemWriter">

        <property name="resource" value="file:C:/output.dat"/>

        <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="field1,field2...." />
                    </bean>
                </property>
            </bean>
        </property>
    </bean>
like image 616
Shankar Avatar asked Nov 28 '25 01:11

Shankar


2 Answers

Take a look at the ClassifierCompositeItemWriter. This ItemWriter implementation allows you to define a Classifier that chooses which of the defined delegate ItemWriter instances to delegate to. In your case, you'd create a Classifier that decided based on field4 and delegate the writing to the appropriate instance of the FlatFileItemWriter.

You can read more about the ClassifierCompositeItemWriter in the documentation here: http://docs.spring.io/spring-batch/trunk/apidocs/org/springframework/batch/item/support/ClassifierCompositeItemWriter.html

like image 100
Michael Minella Avatar answered Nov 30 '25 17:11

Michael Minella


Use a ClassifierCompositeItemWriter

Calls one of a collection of ItemWriters for each item, based on a router pattern implemented through the provided Classifier.

Router pattern is based on bean content

like image 31
Luca Basso Ricci Avatar answered Nov 30 '25 15:11

Luca Basso Ricci



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!