zoukankan      html  css  js  c++  java
  • springBatch将文件中的数据输出到数据库

    跟着视频做的一个小Demo

    建表语句

    CREATE table customer(
    id BIGINT PRIMARY KEY,
    firstName VARCHAR(50),
    lastName VARCHAR(50),
    birthday VARCHAR(50)
    
    )

    目录结构

    Customer实体类
    package com.practice.itemwriterdb;
    
    public class Customer {
        private Long id;
        private String firstName;
        private String lastName;
        private String birthday;
        public long getId() {
            return id;
        }
    
        public void setId(long id) {
            this.id = id;
        }
    
        public String getFirstName() {
            return firstName;
        }
    
        public void setFirstName(String firstName) {
            this.firstName = firstName;
        }
    
        public String getLastName() {
            return lastName;
        }
    
        public void setLastName(String lastName) {
            this.lastName = lastName;
        }
    
        public String getBirthday() {
            return birthday;
        }
    
        public void setBirthday(String birthday) {
            this.birthday = birthday;
        }
    
        @Override
        public String toString() {
            return "Customer{" +
                    "id=" + id +
                    ", firstName='" + firstName + ''' +
                    ", lastName='" + lastName + ''' +
                    ", birthday='" + birthday + ''' +
                    '}';
        }
    
    
    
    
    }
    DemoApplication
    package com.practice.itemwriterdb;
    
    import org.springframework.batch.core.configuration.annotation.EnableBatchProcessing;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    
    @SpringBootApplication
    @EnableBatchProcessing
    public class DemoApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(DemoApplication.class, args);
        }
    
    }
    FlatFileReaderConfig
    package com.practice.itemwriterdb;
    
    import org.springframework.batch.core.configuration.annotation.StepScope;
    import org.springframework.batch.item.file.FlatFileItemReader;
    import org.springframework.batch.item.file.mapping.DefaultLineMapper;
    import org.springframework.batch.item.file.mapping.FieldSetMapper;
    import org.springframework.batch.item.file.transform.DelimitedLineTokenizer;
    import org.springframework.batch.item.file.transform.FieldSet;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.core.io.ClassPathResource;
    import org.springframework.validation.BindException;
    
    @Configuration
    public class FlatFileReaderConfig {
        @Bean
        public FlatFileItemReader<Customer> flatFileReader(){
            FlatFileItemReader<Customer> reader = new FlatFileItemReader<Customer>();
            reader.setResource(new ClassPathResource("customers.txt"));
         //   reader.setLinesToSkip(1);
    
            //解析数据
            DelimitedLineTokenizer tokenizer = new DelimitedLineTokenizer();
            tokenizer.setNames(new String[]{"id","firstName","lastName","birthday"});
    
            DefaultLineMapper<Customer> mapper = new DefaultLineMapper<>();
            mapper.setLineTokenizer(tokenizer);
            mapper.setFieldSetMapper(new FieldSetMapper<Customer>() {
                @Override
                public Customer mapFieldSet(FieldSet fieldSet) throws BindException {
                    Customer customer = new Customer();
                    customer.setId(fieldSet.readLong("id"));
                    customer.setFirstName(fieldSet.readString("firstName"));
                    customer.setLastName(fieldSet.readString("lastName"));
                    customer.setBirthday(fieldSet.readString("birthday"));
    
                    return customer;
                }
            });
            mapper.afterPropertiesSet();
            reader.setLineMapper(mapper);
            return reader;
        }
    }
    ItemWriterDbConfig
    package com.practice.itemwriterdb;
    
    import org.springframework.batch.item.database.BeanPropertyItemSqlParameterSourceProvider;
    import org.springframework.batch.item.database.JdbcBatchItemWriter;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    
    import javax.sql.DataSource;
    
    @Configuration
    public class ItemWriterDbConfig {
        @Autowired
        private DataSource dataSource;
        @Bean
        public JdbcBatchItemWriter<Customer> itemWriterDb(){
            JdbcBatchItemWriter<Customer> writer = new JdbcBatchItemWriter<Customer>();
                    writer.setDataSource(dataSource);
                    writer.setSql("insert into customer(id,firstName,lastName,birthday) values "+
                    "(:id,:firstName,:lastName,:birthday)");
                    writer.setItemSqlParameterSourceProvider( new BeanPropertyItemSqlParameterSourceProvider<>());
                    return writer;
    
        }
    }
    itemWriterDbDemo
    package com.practice.itemwriterdb;
    
    import org.springframework.batch.core.Job;
    import org.springframework.batch.core.Step;
    import org.springframework.batch.core.configuration.annotation.JobBuilderFactory;
    import org.springframework.batch.core.configuration.annotation.StepBuilderFactory;
    import org.springframework.batch.item.ItemReader;
    import org.springframework.batch.item.ItemWriter;
    import org.springframework.batch.item.file.FlatFileItemReader;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.beans.factory.annotation.Qualifier;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    
    @Configuration
    public class itemWriterDbDemo {
        @Autowired
        private JobBuilderFactory jobBuilderFactory;
    
        @Autowired
        private StepBuilderFactory stepBuilderFactory;
        @Autowired
        @Qualifier("flatFileReader")
        ItemReader<Customer> flatFileItemReader;
        @Autowired
        @Qualifier("itemWriterDb")
        ItemWriter<? super Customer> itemWriterDb;
        @Bean
        public Job itemWriterDemoDbJob(){
            return jobBuilderFactory.get("itemWriterDemoDbJob").start(itemWriterDbDemoStep()).build();
        }
    
        @Bean
        public Step itemWriterDbDemoStep() {
    
    
            return stepBuilderFactory.get("itemWriterDbDemoStep").<Customer,Customer>chunk(10)
                    .reader(flatFileItemReader)
                    .writer(itemWriterDb)
                    .build();
        }
    }

    customers

    1,john,Barrett,1994-10-19 14:11:03
    2,Mary,Barrett2,1999-10-19 14:11:03
    3,lisa,Barrett3,1995-10-19 14:11:03
    运行结果:

  • 相关阅读:
    NGUI 3.5课程(五岁以下儿童)button-图片切换
    跑openstack命令错误【You must provide a username via either -...】
    angular cors跨域资源共享设置 和formdata设定
    PHP 如何获取客户端ip地址
    JavaScript如何生成思维导图(mindmap)
    百度ueditor上传图片时如何设置默认宽高度
    英语发音规则---E字母常见的发音组合有哪些
    google搜索引擎爬虫爬网站原理
    legend2---开发日志10(ajax请求的方法是否同样会执行base控制器里面的方法)
    JS中如何判断对象是对象还是数组
  • 原文地址:https://www.cnblogs.com/Syue/p/12507631.html
Copyright © 2011-2022 走看看