当前位置: 首页 > article >正文

Spring Batch ItemWriter 常见实现类及对比(含 RepositoryItemWriter)

Spring Batch ItemWriter 常见实现类及对比(含 RepositoryItemWriter


1. JdbcBatchItemWriter

适用场景:批量写入关系型数据库(如MySQL、PostgreSQL)。
数据类型:POJO/实体对象。
示例代码

@Bean
public JdbcBatchItemWriter<MyEntity> jdbcWriter(DataSource dataSource) {
    JdbcBatchItemWriter<MyEntity> writer = new JdbcBatchItemWriter<>();
    writer.setDataSource(dataSource);
    writer.setSql("INSERT INTO my_table (id, name) VALUES (:id, :name)");
    writer.setItemSqlParameterSourceProvider(
        new BeanPropertyItemSqlParameterSourceProvider<>()
    );
    writer.setBatchSize(100); // 批量提交大小
    return writer;
}

2. FlatFileItemWriter

适用场景:写入文本文件(如CSV、TXT)。
数据类型:文本数据。
示例代码

@Bean
public FlatFileItemWriter<MyEntity> fileWriter(Resource resource) {
    FlatFileItemWriter<MyEntity> writer = new FlatFileItemWriter<>();
    writer.setResource(resource); // 文件路径(如"classpath:output.csv")
    
    // 配置行聚合器(分隔符、字段映射)
    writer.setLineAggregator(new DelimitedLineAggregator<>() {{
        setDelimiter(",");
        setFieldExtractor(new BeanWrapperFieldExtractor<>() {{
            setNames(new String[] {"id", "name"});
        }});
    }});
    return writer;
}

3. MongoItemWriter

适用场景:写入MongoDB文档。
数据类型:MongoDB文档对象。
示例代码

@Bean
public MongoItemWriter<MyDocument> mongoWriter(MongoOperations operations) {
    MongoItemWriter<MyDocument> writer = new MongoItemWriter<>();
    writer.setTemplate(operations); // MongoDB操作模板
    writer.setCollection("my_collection"); // 集合名称
    return writer;
}

4. JpaItemWriter

适用场景:通过JPA保存实体到数据库。
数据类型:JPA实体对象。
示例代码

@Bean
public JpaItemWriter<MyEntity> jpaWriter(EntityManagerFactory emf) {
    JpaItemWriter<MyEntity> writer = new JpaItemWriter<>();
    writer.setEntityManagerFactory(emf); // JPA实体管理工厂
    return writer;
}

5. RepositoryItemWriter

适用场景:通过Spring Data Repository批量保存数据(如Spring Data JPA/Mongo)。
数据类型:支持Spring Data支持的实体对象。
示例代码

@Bean
public RepositoryItemWriter<MyEntity> repositoryWriter(CrudRepository<MyEntity, Long> repo) {
    RepositoryItemWriter<MyEntity> writer = new RepositoryItemWriter<>();
    writer.setRepository(repo); // Spring Data Repository接口实现
    writer.setMethodName("save"); // 调用Repository的save方法
    return writer;
}

实现类对比表格

实现类适用场景数据类型配置复杂度性能依赖库
JdbcBatchItemWriter关系型数据库批量写入POJO/实体高(批量操作)spring-jdbc
FlatFileItemWriter文件(CSV/TXT)输出文本数据高(需配置格式)spring-batch-infrastructure
MongoItemWriterMongoDB文档写入MongoDB对象spring-data-mongodb
JpaItemWriterJPA实体保存到数据库JPA实体spring-orm
RepositoryItemWriterSpring Data Repository保存Spring Data实体spring-batch-infrastructure
spring-data-commons

关键差异说明:

  1. 性能

    • JdbcBatchItemWriter 因批量操作性能最高,适合高吞吐场景。
    • FlatFileItemWriter 受文件IO限制,性能较低。
  2. 配置复杂度

    • FlatFileItemWriter 需自定义字段映射和分隔符,配置最复杂。
    • RepositoryItemWriter 通过Spring Data简化配置,仅需注入Repository。
  3. 适用场景

    • RepositoryItemWriter 适用于Spring Data集成场景(如JPA、MongoDB),可复用已有的Repository接口。
    • JpaItemWriter 专用于JPA实体,需直接依赖JPA配置。

http://www.kler.cn/a/611226.html

相关文章:

  • 跟着StatQuest学知识07-张量与PyTorch
  • 数字转换(c++)
  • 导出sql命令
  • 卡尔曼滤波入门(二)
  • 【C++网络编程】第5篇:UDP与广播通信
  • 蓝桥杯 R格式
  • K8S学习之基础四十三:k8s中部署elasticsearch
  • 保姆级教程 在linux上启动Docker并且使用IntelliJ DockerCompose一键部署Springboot应用 常见命令
  • C语言-适配器模式详解与实践
  • 技术迭代、流量困境与营销突破:基于开源AI大模型与S2B2C模式的创新路径研究
  • Rust从入门到精通之进阶篇:11.所有权系统详解
  • 第十一节 MATLAB关系运算符
  • 电动自行车/电动工具锂电池PCM方案--SH367003、SH367004、SH79F329
  • 深度分页优化思路
  • C++ 多线程简要讲解
  • Modbus RTU ---> Modbus TCP透传技术实现(Modbus透传、RS485透传、RTU透传)分站代码实现、协议转换器
  • Postman 下载文件指南:如何请求 Excel/PDF 文件?
  • 2025BAT大厂Java面试2000题精选(附答案+考点分析)
  • 人员进出新视界:视觉分析算法的力量
  • 淘宝获取商品sku详情API接口如何调用?