一、说明
在JDBC中,executeBatch这个方法可以将多条dml语句批量执行,效率比单条执行executeUpdate高很多,这是什么原理呢?在mysql和oracle中又是如何实现批量执行的呢?本文将给大家介绍这背后的原理。
二、实验介绍
本实验将通过以下三步进行
a. 记录jdbc在mysql中批量执行和单条执行的耗时
b. 记录jdbc在oracle中批量执行和单条执行的耗时
c. 记录oracle plsql批量执行和单条执行的耗时
相关java和数据库版本如下:Java17,Mysql8,Oracle11G
三、正式实验
在mysql和oracle中分别创建一张表
create table t ( -- mysql中创建表的语句
id int,
name1 varchar(100),
name2 varchar(100),
name3 varchar(100),
name4 varchar(100)
);
create table t ( -- oracle中创建表的语句
id number,
name1 varchar2(100),
name2 varchar2(100),
name3 varchar2(100),
name4 varchar2(100)
);
在实验前需要打开数据库的审计
mysql开启审计:
set global general_log = 1;
oracle开启审计:
alter system set audit_trail=db, extended;
audit insert table by scott; -- 实验采用scott用户批量执行insert的方式
java代码如下:
import java.sql.*;
public class JdbcBatchTest {
/**
* @param dbType 数据库类型,oracle或mysql
* @param totalCnt 插入的总行数
* @param batchCnt 每批次插入的行数,0表示单条插入
*/
public static void exec(String dbType, int totalCnt, int batchCnt) throws SQLException, ClassNotFoundException {
String user = "scott";
String password = "xxxx";
String driver;
String url;
if (dbType.equals("mysql")) {
driver = "com.mysql.cj.jdbc.Driver";
url = "jdbc:mysql://ip/hello?useServerPrepStmts=true&rewriteBatchedStatements=true";
} else {
driver = "oracle.jdbc.OracleDriver";