JDBC基础学习(五)—批处理插入数据
一、批处理介绍
当需要成批插入或者更新记录时。可以采用Java的批量更新机制,这一机制允许多条语句一次性提交给数据库批量处理。通常情况下比单独提交处理更有效率。
JDBC的批量处理语句包括下面两个方法:
addBatch(String): 添加需要批量处理的SQL语句或是参数。
executeBatct(): 执行批量处理语句。
二、批处理的使用
1.使用事务没有批处理
@Test
public void testBatch(){ Connection con = null;
PreparedStatement ps = null; try{
// 保证连接是唯一的,传入相同的Connnection
con = JdbcTools.getConnection();
//开启事务
JdbcTools.beginTx(con);
String sql = "insert into person(name,city) values(?,?)";
ps = con.prepareStatement(sql); long begin = System.currentTimeMillis(); // 插入10000条数据
for(int i = 0;i < 100000;i++){
ps.setString(1,"A"+ i);
ps.setString(2,"BJ");
ps.executeUpdate();
}
//提交事务
JdbcTools.commitTx(con); long end = System.currentTimeMillis();
System.out.println("Time: " + (end - begin)); //14684
}catch(Exception e){
e.printStackTrace();
// 回滚事务
JdbcTools.rollBackTx(con);
}finally{
JdbcTools.releaseResource(con,null,null);
}
}
结果: Time: 15127
2.使用事务+批处理
@Test
public void testBatch2(){ Connection con = null;
PreparedStatement ps = null; try{
// 保证连接是唯一的,传入相同的Connnection
con = JdbcTools.getConnection();
//开启事务
JdbcTools.beginTx(con);
String sql = "insert into person(name,city) values(?,?)";
ps = con.prepareStatement(sql); long begin = System.currentTimeMillis(); // 插入10000条数据
for(int i = 0;i < 100000;i++){
ps.setString(1,"A"+ i);
ps.setString(2,"BJ"); //"积攒"SQL
ps.addBatch(); if((i + 1) % 300 == 0){
ps.executeBatch();
ps.clearBatch();
} }
if(100000 % 300 != 0){
ps.executeBatch();
ps.clearBatch();
} //提交事务
JdbcTools.commitTx(con); long end = System.currentTimeMillis();
System.out.println("Time: " + (end - begin)); //17010
}catch(Exception e){
e.printStackTrace();
// 回滚事务
JdbcTools.rollBackTx(con);
}finally{
JdbcTools.releaseResource(con,null,null);
}
}
结果: Time: 17201
看到这个结果,哎呦卧槽,你泥马不是坑爹么,这批处理逗我玩呢。经过百度、Google才得知如下的内容。
在MySQL JDBC连接字符串中还可以加入参数。
rewriteBatchedStatements=true。
mysql默认关闭了batch处理,通过此参数进行打开,这个参数可以重写向数据库提交的SQL语句。
useServerPrepStmts=false。
如果不开启(useServerPrepStmts=false),使用com.mysql.jdbc.PreparedStatement进行本地SQL拼装,最后送到db上就是已经替换了?后的最终SQL。在此稍加改进,连接字符串中加入下面语句。
connectStr += "?useServerPrepStmts=false&rewriteBatchedStatements=true";
再次运行结果: Time: 1933
JDBC基础学习(五)—批处理插入数据的更多相关文章
- Java JDBC批处理插入数据操作
在此笔记里,我们将看到我们如何可以使用像Statement和PreparedStatement JDBC API来批量在任何数据库中插入数据.此外,我们将努力探索一些场景,如在内存不足时正常运行,以及 ...
- Java JDBC批处理插入数据操作(转)
在此笔记里,我们将看到我们如何可以使用像Statement和PreparedStatement JDBC API来批量在任何数据库中插入数据.此外,我们将努力探索一些场景,如在内存不足时正常运行,以及 ...
- FreeSql (五)插入数据
var connstr = "Data Source=127.0.0.1;Port=3306;User ID=root;Password=root;" + "Initia ...
- Python基础学习五
Python基础学习五 迭代 for x in 变量: 其中变量可以是字符串.列表.字典.集合. 当迭代字典时,通过字典的内置函数value()可以迭代出值:通过字典的内置函数items()可以迭代出 ...
- JDBC基础学习(三)—处理BLOB类型数据
一.BLOB类型介绍 在MySQL中,BLOB是一个二进制的大型对象,可以存储大量数据的容器,它能容纳不同大小的数据. 在MySQL中有四种BLOB类型. 实际使 ...
- JDBC基础学习(一)—JDBC的增删改查
一.数据的持久化 持久化(persistence): 把数据保存到可掉电式存储设备中以供之后使用.大多数情况下,数据持久化意味着将内存中的数据保存到硬盘上加以固化,而持久化的实现过程大多通过各 ...
- JDBC基础学习(二)—PreparedStatement
一.PreparedStatement介绍 在SQL中包含特殊字符或SQL的关键字(如: ' or 1 or ')时Statement将出现不可预料的结果(出现异常或查询的结果不正确),可用P ...
- JDBC连接数据库:单线程、多线程、批处理插入数据的对比
一.单线程(单条循环)插入50000条记录: 每执行一次就要访问一次数据库 import java.sql.Connection; import java.sql.DriverManager; imp ...
- 【JDBC】学习路径6-SQL插入、修改、删除数据
第一章:插入使用.executeUpdate(); 返回的是受到影响的数据条数. public static boolean insert(String username,String passwor ...
随机推荐
- ETL kettle 数据调取防止意外停止处理
pentaho kettle是目前使用比较广泛的一种etl工具 但是在使用的时候如做定时任务 会存在如果任务异常停止会发生数据不准或者丢失数据的情况 这种情况在<Pentho Kettle So ...
- HTTP和HTTPS协议
网络协议为计算机网络中进行数据交换而建立的规则.标准或约定的集合. URL:就是网址.http://www.hcios.com/archives/1547 URL就是资源的地址,位置.互联网上的每一个 ...
- stm32 复位后 引起引脚的变化,输出电平引起的问题
在做项目的时候,需要通过蓝牙发送指令给STM32,使其复位,然后进入bootloader程序进行升级,但是复位后会导致蓝牙模块关机.stm32有个引脚连接着蓝牙的开关机引脚,高电平开机,低电平关机,我 ...
- JavaScript知识点总结
JavaScript学习总结1.JavaScript是作用于网络和HTML的一个编程语言.2.JavaScript代码必须放在<script></script>标签之间,Jav ...
- 9 个用于移动APP开发的顶级 JavaScript 框架
顶级 Java 框架 对于Web开发而言,Java是一个有前途的编程语言,并且在不久的将来它将依然在这个领域大放光彩.Java在移动app开发上也有同样的影响吗?让我们一起来看看ValueCoders ...
- maven新建的项目,不自动引入依赖包
1.检查repository的目录是不是纯英文. 2.重新下载一次repository. 如果解决了问题,那么原因就是前面在加载repository的时候,因为断网导致了下载的包有误,无法被ecl ...
- 3389: [Usaco2004 Dec]Cleaning Shifts安排值班
3389: [Usaco2004 Dec]Cleaning Shifts安排值班 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 102 Solved: ...
- python + selenium <四>
层级定位 swich_to_alert swich_to_frame swich_to_window 1. driver.switch_to_alert().accept()#最简单,直接点击确定关闭 ...
- C# 使用 USB转串 接收数据 问题
C# 使用 USB转串 接收数据的 问题 硬件设备是MicroUSB接口,通过USB转串驱动接入PC机.自己用winForm写了一个读取串口数据的小程序,总是接收不到数据. 用传sscom32串口工具 ...
- WPF: 在 MVVM 设计中实现对 ListViewItem 双击事件的响应
ListView 控件最常用的事件是 SelectionChanged:如果采用 MVVM 模式来设计 WPF 应用,通常,我们可以使用行为(如 InvokeCommandAction)并结合命令来实 ...