批处理就是执行多个操作
1. 业务场景:
当需要向数据库发送一批SQL语句执行时,应避免向数据库一条条的发送执行,而应采用JDBC的批处理机制,以提升执行效率。
2. API:
添加批处理
void addBatch(String sql)
执行批处理
int[] executeBatch()
清空批处理
void clearBatch()
需求:程序有100个users对象(list集合),需要插入数据库
解决1:
写一个save方法,实现一次插入一条记录,再循环执行100次
缺点:1.频繁打开、关闭连接
2.效率低
希望:
打开一次连接,发送多条sql语句执行;最后执行完再关闭!
解决2:使用批处理!
批处理实现方式1:Statement.addBatch(sql)
@Test
public void testBatch1(){
try {
conn = JdbcUtil.getConnection();
String sql1 = "insert into users(username,pwd) values('tom','123')";
String sql2 = "update users set pwd='123456' where id=3";
stmt = conn.createStatement();
stmt.addBatch(sql1); //把SQL语句加入到批命令中
stmt.addBatch(sql2); //把SQL语句加入到批命令中
stmt.executeBatch();
} catch (SQLException e) {
throw new RuntimeException(e);
}finally{
JdbcUtil.closeAll(conn, stmt, rs);
}
}
小结1:
采用Statement.addBatch(sql)方式实现批处理:
优点:
可以向数据库发送多条不同的SQL语句。
缺点:
1.SQL语句没有预编译。
2.当向数据库发送多条语句相同,但仅参数不同的SQL语句时,需重复写上很多条SQL语句。例如:
Insert into user(name,password) values(‘aa’,’111’);
Insert into user(name,password) values(‘bb’,’222’);
Insert into user(name,password) values(‘cc’,’333’);
Insert into user(name,password) values(‘dd’,’444’);
批处理实现方式2---PreparedStatement.addBatch()
实现代码:
@Test
public void testBatch2(){
try {
conn = JdbcUtil.getConnection();
String sql = "insert into users(username,pwd) values(?,?)";
pstmt = conn.prepareStatement(sql);
for(int i=0;i<50000;i++){
pstmt.setString(1, "name" + i);
pstmt.setString(2,(UUID.randomUUID()+"").substring(0,10));
pstmt.addBatch();
//每1000条执行一次
if(i%1000==0){
pstmt.executeBatch();
pstmt.clearBatch();
}
}
pstmt.executeBatch();
} catch (SQLException e) {
throw new RuntimeException(e);
}finally{
JdbcUtil.closeAll(conn, pstmt, rs);
}
}
小结2:
采用PreparedStatement.addBatch()实现批处理
优点:
发送的是预编译后的SQL语句,执行效率高。
缺点:
只能应用在SQL语句相同,但参数不同的批处理中。因此此种形式的批处理经常用于在同一个表中批量插入数据,或批量更新表的数据。