我正在使用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> {
....
}
答案 0 :(得分:1)
你的意思是BeanPropertySqlParameterSource吗?
从中获取参数值的SqlParameterSource实现 给定JavaBean对象的bean属性。豆的名字 属性必须与参数名称匹配。
使用Spring BeanWrapper进行下面的bean属性访问。