java - 使用批处理作业的 FlatFileItemReader 和 FlatFileItemWriter

标签 java xml spring-mvc spring-batch flatfilereader

我想从文本文件中读取、解析和写入数据。我实现了这一点,但我对标识符的声明有疑问。我在下面展示了我的类(class)。

CustomerDataMapper.java

public class CustomerDataMapper implements FieldSetMapper<Customer> {
     private static Log log = LogFactory.getLog(CustomerDataMapper.class);

     @Override
     public RawData mapFieldSet(FieldSet fieldSet) throws BindException {
          Customer customer = new Customer();

          try {
              customer.setCustNum(fieldSet.readInt("id"));
              customer.setNameSurname(fieldSet.readString("name"));
          }catch (Exception e){
              log.error("Mapping error, " + e);
          }
          return customer;
     }
}

Customer.java

@Component
@Scope("prototype")
public class Customer implements Serializable{
    private Integer custNum;
    private String nameSurname;

    public String getCustNum) {
        return custNum;
    }

    public void setCustNum(String custNum) {
        this.custNum = custNum;
    }

    public String getNameSurname() {
        return nameSurname;
    }

    public void setNameSurname(String nameSurname) {
        this.nameSurname = nameSurname;
    }
}

fileManager.xml

<bean id="customerFileItemReader" class="org.springframework.batch.item.file.FlatFileItemReader" scope="step">
    <property name= "encoding" value ="Cp1254"/>                           
    <property name="resource" value="#{jobParameters['processPath']}"/>
    <property name="lineMapper">
    <bean class="org.springframework.batch.item.file.mapping.DefaultLineMapper">
        <property name="lineTokenizer">
            <bean class="org.springframework.batch.item.file.transform.FixedLengthTokenizer">
                <property name="names" value="id, name"/>
                <property name="columns" ref="1-9, 10-30"/>
            </bean>
        </property>
        <property name="fieldSetMapper">
            <bean class="mapper.CustomerDataMapper ">
                <property name="fileName" value="#{jobParameters['fileNameAndTime']}"/>
            </bean>
        </property>
    </bean>
</property>

<bean id="customerFileItemWriter" class="org.springframework.batch.item.database.JdbcBatchItemWriter">
    <property name="dataSource" ref="dataSource"/>
    <property name="sql">
        <value>
            <![CDATA[
                insert into CUSTOMER(CUST_NUM, NAME_SURNAME)
                values (:custNum, :nameSurname)
            ]]>
        </value>
    </property>
    <property name="itemSqlParameterSourceProvider">
    <bean class="org.springframework.batch.item.database.BeanPropertyItemSqlParameterSourceProvider"/>
</property>

 <bean id = "customerSkipListener" class="listener.CustomerSkipListener"/>

<batch:job id="customerImportJob">
    <batch:step id="smsPasswordDataImportStep">
        <batch:tasklet>
            <batch:chunk reader="customerFileItemReader" writer="customerFileItemWriter" commit-interval="1" skip-limit="1000">
            <batch:skippable-exception-classes>
                <batch:include class="java.lang.Exception"/>
                <batch:exclude class="java.io.FileNotFoundException"/>
            </batch:skippable-exception-classes> <batch:listeners>
            <batch:listener ref="customerSkipListener" />
        </batch:listeners>
        </batch:chunk>
    </batch:tasklet>

</batch:step>

我想问一下,我可以将下面这个类用于FieldSetMapper吗?如果我在定义标识符时不使用驼峰命名法,则无法写入数据库。有没有这方面的思路或者方法。非常感谢。

Customer.java

@Component
@Scope("prototype")
public class Customer implements Serializable{

private Integer Cust_Num;
private String Name_Surname;

public String getCust_Num() {
    return Cust_Num;
}

public void setCust_Num(String Cust_Num) {
    this.Cust_Num = Cust_Num;
}

public String getName_Surname() {
    return Name_Surname;
}

public void setName_Surname(String Name_Surname) {
    this.Name_Surname = Name_Surname;
}
}

最佳答案

I want to ask this, Can use this class for FieldSetMapper

是的,你可以使用这个类。由于您编写了自定义 FieldSetMapper ,您可以控制映射逻辑。你的映射器会是这样的:

public class CustomerDataMapper implements FieldSetMapper<Customer> {
   private static Log log = LogFactory.getLog(CustomerDataMapper.class);

   @Override
   public RawData mapFieldSet(FieldSet fieldSet) throws BindException {
      Customer customer = new Customer();

      try {
          customer.setCust_Num(fieldSet.readInt("id"));
          customer.setName_Surname(fieldSet.readString("name"));
      }catch (Exception e){
          log.error("Mapping error, " + e);
      }
      return customer;
   }
}

但是您的问题不在阅读方(以及 FieldSetMapper ),而是在作者方。 JdbcBatchItemWriter使用 ItemSqlParameterSourceProvider从您的 Customer 中提取数据对象并将它们设置在 sql 查询上。默认情况下,BeanPropertyItemSqlParameterSourceProvider使用时,此实现根据 JavaBeans 命名约定提取数据。但是,您可以提供自定义实现,在您的情况下,该实现类似于:

class CustomerItemSqlParameterSourceProvider implements ItemSqlParameterSourceProvider<Customer> {

    @Override
    public SqlParameterSource createSqlParameterSource(Customer customer) {
        Map<String, Object> params = new HashMap<>();
        params.put("custNum", customer.getCust_Num());
        params.put("nameSurname", customer.getName_Surname());
        return new MapSqlParameterSource(params);
    }
}

然后你设置这个CustomerItemSqlParameterSourceProvider关于你的作家。

希望这有帮助。

关于java - 使用批处理作业的 FlatFileItemReader 和 FlatFileItemWriter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54341257/

相关文章:

java - 当元素具有值和子元素时,将转换器与 xstream 一起使用

java - 带 mvc 和自动配置的 Spring Boot

spring-mvc - 如何对Orient DB数据库进行分片和复制

java - Spring MVC 中的多 DispatcherServlet (Java 配置)

java - 无法解决 E/RecyclerView : No adapter attached; skipping layout

android - 卡片 View : How do I add a gradient background while maintaining the radius

java - 在 OnClickListener 中实现 DialogFragment 接口(interface)

xml - 如何使用 as3 删除 xml 标签

Java 并发 : Countdown latch vs Cyclic barrier

java - 为什么我无法获得矩阵元素的正确结果?