使用 rewriteBatchedStatements=true 时,JDBC 会将尽可能多的查询打包到单个网络数据包中,从而降低网络开销。我说的对吗?
是的。以下代码
String myConnectionString =
"jdbc:mysql://localhost:3307/mydb?" +
"useUnicode=true&characterEncoding=UTF-8";
try (Connection con = DriverManager.getConnection(myConnectionString, "root", "whatever")) {
try (PreparedStatement ps = con.prepareStatement("INSERT INTO jdbc (`name`) VALUES (?)")) {
for (int i = 1; i <= 5; i++) {
ps.setString(1, String.format(
"Line %d: Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.",
i));
ps.addBatch();
}
ps.executeBatch();
}
}
即使我创建了一个批处理,也会发送单独的 INSERT 语句
INSERT INTO jdbc (`name`) VALUES ('Line 1: Lorem ipsum ...')
INSERT INTO jdbc (`name`) VALUES ('Line 2: Lorem ipsum ...')
但是,如果我将连接字符串更改为包含 rewriteBatchedStatements=true
String myConnectionString =
"jdbc:mysql://localhost:3307/mydb?" +
"useUnicode=true&characterEncoding=UTF-8" +
"&rewriteBatchedStatements=true";
然后 JDBC 将发送一个或多个多行 INSERT 语句
INSERT INTO jdbc (`name`) VALUES ('Line 1: Lorem ipsum ...'),('Line 2: Lorem ipsum ...')
JDBC 是否知道分配给 max_allowed_packet 的值并因此使数据包小于为 max_allowed_packet 定义的值...?
是的。如果启用 MySQL 常规日志并检查它,您将看到 MySQL Connector/J 在连接时检查一堆变量,其中一个是 max_allowed_packet。您还可以设置一个小的 max_allowed_packet 值并验证 JDBC 是否将一个批处理拆分为多个多行 INSERT 语句,如果整个批处理的单个此类语句将超过 max_allowed_packet。