spring批量从BeanWrapperFieldSetMapper获取SQLParameterSource

时间:2014-03-31 17:51:06

标签: spring-batch

我正在使用BeanWrapperFieldSetMapper将CSV文件的内容映射到自定义bean。是否有一个spring批量实用程序类,它将此bean转换为实现SQLParameterSource接口的对象。我正在寻找一个类,它将使用反射来填充MapSqlParameterSource类,使用自定义bean字段名称和关联值以及键/值对。

这是我目前的工作配置

<bean id="abcFileReaderDBLoaderJob" parent="simpleJob">
    <property name="steps">
        <list>
            <bean parent="simpleStep">
                <property name="itemReader">
                    <bean class="org.springframework.batch.item.file.FlatFileItemReader">
                        <property name="lineMapper">
                            <bean class = "org.springframework.batch.item.file.mapping.DefaultLineMapper">
                                <property name="lineTokenizer">
                                    <bean class="org.springframework.batch.item.file.transform.DelimitedLineTokenizer">
                                        <property name="strict" value="false"/>
                                        <property name="names" value="a,b,c" />
                                    </bean>
                                </property>
                                <property name="fieldSetMapper">
                                    <bean class="org.springframework.batch.item.file.mapping.BeanWrapperFieldSetMapper">
                                        <property name="prototypeBeanName" value="abcBean"/>
                                    </bean>
                                </property>
                            </bean>
                        </property>
                        <property name="resource">
                            <bean class="org.springframework.core.io.FileSystemResource">
                                <constructor-arg value="${abc.file}" />
                            </bean>
                        </property>
                    </bean>
                </property>
                <property name="itemWriter" ref="abcTableWriter"/>
            </bean>
        </list>
    </property>
</bean>

我的通用表编写器有这个接口

/**
 * Takes a list of SqlParameterSource and writes to the DB.
 */
public class TableWriter implements ItemWriter<SqlParameterSource> {
    ....
}

1 个答案:

答案 0 :(得分:1)

你的意思是BeanPropertySqlParameterSource吗?

  

从中获取参数值的SqlParameterSource实现   给定JavaBean对象的bean属性。豆的名字   属性必须与参数名称匹配。

     

使用Spring BeanWrapper进行下面的bean属性访问。