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

读取数据库数据

一、定义一个读写的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. (转)st(state-threads) coroutine调度

    目录(?)[-] EPOLL和TIMEOUT TIME TIMEOUT Deviation   st(state-threads) https://github.com/winlinvip/state ...

  2. (转)YUV420、YUV422、RGB24转换

    //平面YUV422转平面RGB24static void YUV422p_to_RGB24(unsigned char *yuv422[3], unsigned char *rgb24, int w ...

  3. 一款标注颜色,距离的小软件 markman

    长度标记   坐标和矩形标记   色值标记   文字标记   长度自动测量   标记拖拽删除   支持多种图片格式 支持PSD(需用最大兼容保存).PNG.BMP.JPG格式 设计稿自动刷新 在标注的 ...

  4. js 跨域 Jquery取得iframe中元素的几种方法

    http://www.jb51.net/article/34942.htm 收集利用Jquery取得iframe中元素的几种方法 : 父页面访问子页面 $(document.getElementByI ...

  5. Spring-core中的cglib小用法

    对象复制听说用这个更高效 /** * 拷贝对象 * @param src 源对象 * @param dist 需要赋值的对象 */ public static void copy(Object src ...

  6. UNIX环境编程学习笔记(15)——进程管理之进程终止

    lienhua342014-10-02 1 进程的终止方式 进程的终止方式有 8 种,其中 5 种为正常终止,它们是 1. 从 main 返回. 2. 调用 exit. 3. 调用_exit 或_Ex ...

  7. Oracle:oratop 第一栏中的 {n}er 的含义,及如何清除这个er

    在oratop监控中: 第一栏的er[不]为{0}!说明Oracle的ADR诊断体系内发现有错误事件(problem + incident) 该信息实际是从一张视图内得来的: select * fro ...

  8. unity之UGUI屏幕分辨率調整

    1.Canvas的屬性配置: 2.Canvas Scaler的屬性配置: 3.根據不同的屏幕比例動態寫改碩放基準: public float standard_width = 800f; //初始宽度 ...

  9. Ruby 面向对象知识详解

    Ruby 是纯面向对象的语言,Ruby 中的一切都是以对象的形式出现.Ruby 中的每个值都是一个对象,即使是最原始的东西:字符串.数字,甚至连 true 和 false 都是对象.类本身也是一个对象 ...

  10. linux环境中,如何查看某个软件包,都依赖哪些软件包?被哪些软件包依赖?

    需求描述: 今天查看主机上的一个软件ghostscript,准备删除,就先看下这个软件都依赖哪些软件, 然后呢被哪些软件依赖 操作过程: 1.查看这个软件依赖哪些软件(rpm方式查询) [root@t ...