这里我们介绍一个从数据库读取数据并写入到文件中的案例。如果能真心爱上一个人,那么不管对方是何等恶劣,哪怕对方并不爱自己,人生也至少不会是地狱,就算多少有点黯淡。

读取数据库数据

一、定义一个读写的job

<!--读取数据库数据到文件-->
<job id="readDatabaseJob">
<step id="readDatabaseStep">
<tasklet transaction-manager="transactionManager">
<chunk reader="userReader" commit-interval="100" writer="userWriter"/>
</tasklet>
</step>
</job>

二、定义并实现读取数据库的reader

<!--读取数据库到文件中-->
<bean id="userReader" class="org.springframework.batch.item.database.JdbcCursorItemReader">
<property name="sql" value="select user_name, age, address, birthday from batch_user where age > ?;"/>
<property name="rowMapper" ref="userRowMapper"/>
<property name="dataSource" ref="dataSource"/>
<property name="preparedStatementSetter" ref="paramStatementSetterUser"/>
</bean>
<bean id="userRowMapper" class="spring.batch.readDatabase.UserRowMapper"/>
<bean id="paramStatementSetterUser" class="org.springframework.batch.core.resource.ListPreparedStatementSetter" scope="step">
<property name="parameters">
<list>
<value>#{jobParameters['age']}</value>
</list>
</property>
</bean>

上述的UserRowMapper类代码如下

package spring.batch.readDatabase;

import org.springframework.jdbc.core.RowMapper;
import spring.batch.readFile.People; import java.sql.ResultSet;
import java.sql.SQLException; /**
* @Author: huhx
* @Date: 2017-11-02 上午 10:16
*/
public class UserRowMapper implements RowMapper<People> { @Override
public People mapRow(ResultSet rs, int rowNum) throws SQLException {
People people = new People();
people.setUsername(rs.getString("user_name"));
people.setAge(rs.getInt("age"));
people.setAddress(rs.getString("address"));
people.setBirthday(rs.getDate("birthday"));
return people;
}
}

三、定义并实现写入文件的writer

<bean id="userWriter" class="spring.batch.readDatabase.UserFileWriter">
<property name="targetDirectory" value="file"/>
<property name="targetFile" value="user.txt"/>
</bean>

UserFileWriter的实现代码

package spring.batch.readDatabase;

import org.apache.commons.io.FileUtils;
import org.springframework.batch.item.ItemWriter;
import spring.batch.readFile.People; import java.io.File;
import java.util.List; /**
* @Author: huhx
* @Date: 2017-11-02 上午 10:19
*/
public class UserFileWriter implements ItemWriter<People> { private String targetDirectory;
private String targetFile; public void setTargetDirectory(String targetDirectory) {
this.targetDirectory = targetDirectory;
} public void setTargetFile(String targetFile) {
this.targetFile = targetFile;
} @Override
public void write(List<? extends People> items) throws Exception {
File targetDirectoryAsFile = new File(targetDirectory);
if (!targetDirectoryAsFile.exists()) {
FileUtils.forceMkdir(targetDirectoryAsFile);
}
File target = new File(targetDirectory, targetFile);
FileUtils.writeLines(target, items, true);
}
}

四、其它的一些信息及注意的地方

  • 这里我们复写了People类的toString方法
@Override
public String toString() {
return "username=" + username + "|age=" + age + "|address=" + address + "|birthday=" + birthday;
}
  • JobLaunch.java类里面,我们增加参数
JobParameters jobParameters = parametersBuilder.addString("age", "25").toJobParameters();
  • 数据库表user_batch的所有数据

  • 最终生成的user.txt的文件内容如下
username=孙尚香|age=|address=天津|birthday=--
username=牛魔王|age=|address=武汉|birthday=--

友情链接

springbatch---->springbatch的使用(五)的更多相关文章

  1. SpringBatch Sample (五)(复合格式文件的读、多文件的写)

    前面关于Spring Batch的文章,讲述了SpringBatch对CSV文件的读写操作.对XML文件的操作,以及对固定长格式文件的操作.这些事例,同一个Reader读取的都是相同格式的数据,最终写 ...

  2. YII内置验证规则

    required: 必填字段验证, 来自 CRequiredValidator类的别名 array(‘字段名列表用逗号隔开’, ‘required’),    就这样的一个小小的写法,可以让字段前面加 ...

  3. Spring Batch介绍

    简介 SpringBatch 是一个大数据量的并行处理框架.通常用于数据的离线迁移,和数据处理,⽀持事务.并发.流程.监控.纵向和横向扩展,提供统⼀的接⼝管理和任务管理;SpringBatch是Spr ...

  4. SpringBoot整合SpringBatch

    一.引入依赖 pom.xml <?xml version="1.0" encoding="UTF-8"?> <project xmlns=&q ...

  5. springbatch操作CSV文件

    一.需求分析 使用Spring Batch对CSV文件进行读写操作: 读取一个含有四个字段的CSV文件(id, name, age, score), 对文件做简单的处理, 然后输出到还有一个csv文件 ...

  6. SpringBatch的核心组件JobLauncher和JobRepository

    Spring Batch的框架包括启动批处理作业的组件和存储Job执行产生的元数据.因此只需掌握配置这个基础框架在批处理应用程序中即启动Jobs并存储Job元数据. 组件:Job Launcher和J ...

  7. SpringBatch简介

    spring Batch是一个轻量级的.完善的批处理框架,旨在帮助企业建立健壮.高效的批处理应用.SpringBatch是Spring的一个子项目,使用Java语言并基于Spring框架为基础开发,使 ...

  8. spring-boot-oracle spring-batch

    Install/Configure Oracle express Oracle xe installer for linux (I don't care if you're running linux ...

  9. springbatch的封装与使用

    springbatch 主要实现批量数据的处理,我对batch进行的封装,提出了jobBase类型,具体job需要实现它即可.Spring Batch 不仅提供了统一的读写接口.丰富的任务处理方式.灵 ...

  10. SpringBatch的流程简介

    SpringBatch的流程图如下: 每个Batch都会包含一个Job.Job就像一个容器,这个容器装了若干Step,Batch中实际干活的也就是这些Step,至于Step干什么活,无外乎读取数据,处 ...

随机推荐

  1. (转)ffmpeg 从mp4上提取H264的nalu

     出自:http://blog.csdn.net/gavinr/article/details/7183499   1.获取数据ffmpeg读取mp4中的H264数据,并不能直接得到NALU,文件中也 ...

  2. 微服务架构eureka集群高可用配置

    工具:idea 环境:java8.maven3 版本:spring boot 1.5.15.RELEASE 1.搭建spring boot eureka项目 2. pom.xml添加相应依赖,如下: ...

  3. Objective-c: 移除字符串中的指定字符

    string = [[string componentsSeparatedByCharactersInSet:[NSCharacterSet characterSetWithCharactersInS ...

  4. 正则表达式(Java版整理)

    基础 元字符 代码 说明 . 匹配除换行符以外的任意字符 \w 匹配字母或数字或下划线或汉字 \s 匹配任意的空白符 \d 匹配数字 ^ 匹配字符串的开始 $ 匹配字符串的结束 \b 匹配字符串的结束 ...

  5. find命令/文件名后缀

    2.23/2.24/2.25 find命令 2.26 文件名后缀 find 搜索文件的命令: which   它是从环境变量中找: [root@centos_1 ~]# which ls alias ...

  6. UNIX环境编程学习笔记(6)——文件I/O之判断文件类型

    lienhua342014-09-01 1 文件类型 我们平时最常接触的文件类型有普通文件(regular file)和目录(di-rectory file),但是 UNIX 系统提供了多种文件类型: ...

  7. Xcode不太常见又实用的小技巧

    备份, 原文: http://rocry.com/2012/12/17/xcode-tips/ 让代码中的TODO和FIXME变成Warning 选中某个Target > Build Phase ...

  8. 关于error:Cannot assign to 'self' outside of a method in the init family

    有时候我们重写父类的init方法时不注意将init后面的第一个字母写成了小写,在这个方法里面又调用父类的初始化方法(self = [super init];)时会报错,错误信息如下:error:Can ...

  9. Okhttp封装、网络层扩展

    一.概述 首先在这里本片文章是以网络通信封装为主,而app开发首先重要就是网络通信,而如今主流的async.volley.okhttp等,阿么这么网络库怎样能做到更好封装.更好的切换,从而不影响业务层 ...

  10. java序列化/反序列化之xstream、protobuf、protostuff 的比较与使用例子

    目录 背景 测试 环境 工具 说明 结果 结论 xstream简单教程 准备 代码 protobuf简单教程 快速入门 下载.exe编译器 编写.proto文件 利用编译器编译.proto文件生成ja ...