从零开始学JDBC--1.13 批处理
来源:互联网 发布:apache开启rewrite 编辑:程序博客网 时间:2024/06/06 02:42
批处理就是执行多个操作
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语句相同,但参数不同的批处理中。因此此种形式的批处理经常用于在同一个表中批量插入数据,或批量更新表的数据。
- 从零开始学JDBC--1.13 批处理
- 从零开始学JDBC--1.2 JDBC核心接口
- 从零开始学JDBC--1.8 CallableStatement-- 存储过程
- 从零开始学JDBC--1.1 最简单的jdbc连接方式
- 从零开始学JDBC--1.5 DML代码抽取,结构简化
- 从零开始学JDBC--1.6 DQL--ResultSet的遍历方法
- 从零开始学JDBC--1.7 PreparedStatement-- 预编译sql
- 从零开始学JDBC--1.9 代码抽取--使用Properties读取配置文件
- 从零开始学JDBC--1.10 资源释放代码的优化
- 从零开始学JDBC--1.11 事务机制以及案例分析
- 从零开始学JDBC--1.14 BeanUtils组件的用法
- 从零开始学JDBC--1.15 ConvertUtils组件的用法
- 从零开始学JDBC--1.19 连接池工具--DBCP
- 从零开始学JDBC--1.9 代码抽取--使用Properties读取配置文件
- JDBC批处理
- jdbc批处理
- JDBC批处理
- JDBC批处理
- AndroidStudio Gradle:Resolvedependencies':app:_debugCompile' 问题
- 常用js整理
- 172. Factorial Trailing Zeroes
- Android一个TextView文字颜色不同或多个关键字不同颜色
- 【LightOJ】1410 - Consistent Verdicts(思维)
- 从零开始学JDBC--1.13 批处理
- x264代码剖析(七):encode()函数之x264_encoder_encode()函数
- hdu1717(小数化分数)
- 进度条(ProgressBar)的功能与用法
- 会话-Cookie
- 对称矩阵与压缩存储算法(java实现)
- FPGA
- dubbox开发rest+json指南
- 知识库