2014-10-10 105 views
28

我一直在看周围,hereherehere有关使用rewriteBatchedStatements=trueMySQL和JDBC与rewriteBatchedStatements =真

的优势。如果我的理解是正确的,与rewriteBatchedStatements=true的JDBC将尽可能多的查询,可能集成到一个网络数据包中,从而降低网络开销。我对吗?

然后它引起我的注意,在max_allowed_packet的MySQL服务器中定义的值可能会导致查询问题(查询未在服务器上执行)。

所以我的第二个问题是,JDBC是否知道分配给max_allowed_packet的值,因此使数据包小于max_allowed_packet的定义值,或者这是开发人员必须考虑的事情?

如果我理解错误,请让我知道。

+0

为什么要投票?谨慎解释? – dazito 2014-10-10 20:45:44

回答

39

with rewriteBatchedStatements = true J​​DBC会将尽可能多的查询打包到单个网络数据包中,从而降低网络开销。我对吗?

是。下面的代码

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_pa​​cket的值,因此使数据包小于max_allowed_pa​​cket的定义值...?

是。如果启用MySQL通用日志并检查它,您会看到MySQL Connector/J在连接时会检查一堆变量,其中一个是max_allowed_packet。您还可以设置一个小的max_allowed_packet值,并验证JDBC是否将批次拆分为多个多行INSERT语句,如果整个批次的单个语句将超过max_allowed_packet

+3

但对ACID有副作用:如果没有rewriteBatchedStatements,我们可能会插入一部分行,但现在即使只有一个重复键,我们也可以插入任何内容。 – auntyellow 2014-12-31 14:47:23

+3

请注意:您不应关闭'con'和'ps',因为它会被try-with-resources块自动关闭。 – Benjamin 2016-04-28 12:42:32

+0

@Benjamin - 我已经更新了代码。谢谢。 – 2016-10-27 00:35:16