JDBC之批处理
JDBC之批处理
现在有这么一个需求,要求把2000条记录插入表中,如果使用java代码来操作,我们可以使用Statement或者PreparedStatement来实现,通过循环来把SQL语句一条又一条地发送给数据库处理。我们知道,数据库处理SQL速度是非常快的,如果传输速度慢,跟不上处理速度,那么数据库就会出现等待现象。为了解决这个办法,我们可以一次发送多个SQL语句给数据库处理,这样就能增加效率,这时候我们就要用到批处理技术。
然而,批处理也可以通过Statement和Preparement来实现,要用到的主要方法如下:
Statement批处理操作:
void addBatch(String sql) --把SQL语句加到批处理缓冲区中
int[] executeBatch() --执行SQL缓冲区中的所有语句
void clearBatch() --清空缓存区中的所有SQL语句
PreparedStatement操作:
void addBatch(String sql) --把一组参数加到参数缓冲区中
int[] executeBatch() --执行SQL缓冲区中的所有参数组
void clearBatch() --清空缓存区中的所有参数组
下面就演示一下这些方法的用法吧~
利用Statement
@Test
public void batchTest() throws Exception{
//调用工具类获取连接
connection = sqlUtil.getconnection(); //生成Statemnt对象
Statement statement = connection.createStatement(); //把若干条SQL语句放到缓冲区中
for(int i=1;i<=200;i++){
//准备sql语句
String sql = "insert into worker(wid,wname) values("+i+",'张三"+i+"')";
//添加到缓冲区
statement.addBatch(sql); if(i%20==0){
System.out.println("共"+ i +"条语句插入了表中");
//缓存区有20条指令时执行
statement.executeBatch();
//执行完清空缓存区
statement.clearBatch();
}
}
//关闭连接
sqlUtil.close(statement, connection);
}
利用PreparedStatement
public void batchTest2() throws Exception{
//调用工具类获取连接
connection = sqlUtil.getconnection(); //生成Statemnt对象
PreparedStatement prepS = connection.prepareStatement("insert into worker(wid,wname) values(?,?)"); //把若干条SQL语句放到缓冲区中
for(int i=1;i<=200;i++){
//设置参数
prepS.setObject(1, i);
String wname = "李四"+i;
prepS.setObject(2, wname); //添加到缓冲区
prepS.addBatch(); if(i%20==0){
System.out.println("共"+ i +"条语句插入了表中");
//缓存区有20条指令时执行
prepS.executeBatch();
//执行完清空缓存区
prepS.clearBatch();
}
}
//关闭连接
sqlUtil.close(prepS, connection);
}
以上就是利用JDBC实现批处理了~
如果想要执行效率最快,我们应该使用 prepareStatemnt + 批处理 这样的方式来执行多条SQL语句。
JDBC之批处理的更多相关文章
- JDBC的批处理操作三种方式 pstmt.addBatch()
package lavasoft.jdbctest; import lavasoft.common.DBToolkit; import java.sql.Connection; import java ...
- JDBC进行批处理
转自 http://mousepc.iteye.com/blog/1131462 业务场景:当需要向数据库发送一批SQL语句执行时,应避免向数据库一条条的发送执行,而应采用JDBC的批处理机制,以提升 ...
- 使用JDBC进行批处理
在实际的项目开发中,有时候需要向数据库发送一批SQL语句执行,这时应避免向数据库一条条的发送执行,而应采用JDBC的批处理机制,以提升执行效率. JDBC实现批处理有两种方式:statement和pr ...
- JavaWeb学习总结(十一)--JDBC之批处理
一.批处理的介绍 在实际的项目开发中,有时候需要向数据库发送一批SQL语句执行,这时应避免向数据库一条条的发送执行,而应采用JDBC的批处理机制,以提升执行效率.批处理只针对更新(增.删.改)语句,批 ...
- javaweb学习总结(三十六)——使用JDBC进行批处理
在实际的项目开发中,有时候需要向数据库发送一批SQL语句执行,这时应避免向数据库一条条的发送执行,而应采用JDBC的批处理机制,以提升执行效率. JDBC实现批处理有两种方式:statement和pr ...
- JDBC的批处理操作三种方式
SQL批处理是JDBC性能优化的重要武器,批处理的用法有三种. package lavasoft.jdbctest; import lavasoft.common.DBToolkit; import ...
- JavaWeb学习笔记(十五)—— 使用JDBC进行批处理
一.什么是批处理 批处理就是一批一批的处理,而不是一个一个的处理! 当你有10条SQL语句要执行时,一次向服务器发送一条SQL语句,这么做效率上很差!处理的方案是使用批处理,即一次向服务器发送多条SQ ...
- JDBC进行批处理Batch
在实际的项目开发中,有时候需要向数据库发送一批SQL语句执行,这时应避免向数据库一条条的发送执行,而应采用JDBC的批处理机制,以提升执行效率. JDBC实现批处理有两种方式:statement和pr ...
- (十七)使用JDBC进行批处理
目录 业务场景: 第一种方式 第二种方式 批处理中的 update() 方法 注意事项 备注: 业务场景: 当需要向数据库中发送一批SQL语句执行时,应避免向数据库一条条的发送执行,而应采用JDBC的 ...
随机推荐
- 【leetcode】 Jump Game
Given an array of non-negative integers, you are initially positioned at the first index of the arra ...
- Jenkins 01——简介
Jenkins是一个开源软件项目,一个可扩展的持续集成引擎.旨在提供一个开放易用的软件平台,使软件的持续集成变成可能. 持续集成是一种开发实践,需要开发人员定期将代码集成到共享存储库中.这个概念意在消 ...
- VS之解决方案文件夹
Visual Studio提供了一种特殊的文件夹,它可以帮助组织大型解决方案.它们的名称也恰如其分,叫做“解决方案文件夹”. 注意 解决方案文件夹是解决方案资源管理器中的一种组织工具,创建这样的文 ...
- CSS media--(来自网易)
概述 通过媒体查询为不同的设备和大小配置不同的样式.代码展示 /* media */ /* 横屏 */ @media screen and (orientation:landscape){ } /* ...
- java学习第05天(数组常见操作、数组中的数组)
(4)数组常见操作 a.遍历取值 class ArrayDemo3 { public static void main(String[] args) { //System.out.println(&q ...
- ListUtil(差集、交集、并集)
package cn.fraudmetrix.octopus.horai.biz.utils; import java.util.ArrayList; import java.util.Arrays; ...
- artDialog学习之旅(一)
接口 配置参数 content: {消息内容,支持HTML} title: {标题.默认:'提示'} lock: {是否锁定屏幕. 默认:false} width: {宽度,支持em等单位. 默认:' ...
- git学习——Git 基础要点【转】
转自:http://blog.csdn.net/zeroboundary/article/details/10549555 简单地说,Git 究竟是怎样的一个系统呢?请注意,接下来的内容非常重要,若是 ...
- urbuntu12.04 ftp服务器搭建
1.安装ftp服务器: sudo apt-get install vsftpd 2..配置ftp 修改ftp的配置文件,该文件在/etc目录下,在终端中键入如下命令以打开配置文件: sudo vi / ...
- java注解方式解析xml格式
注解类和字段方式: @XStreamAlias("message") 别名注解 注解集合: @XStreamImplicit(itemFieldName="part&qu ...