rewriteBatchedStatements=true
JDBC(Java Database Connectivity) 드라이버는 rewriteBatchedStatements=true
매개변수를 통해 상당한 성능 향상을 제공합니다. 이 설정을 사용하면 드라이버가 여러 데이터베이스 쿼리를 단일 네트워크 전송으로 통합하여 네트워크 오버헤드를 크게 줄일 수 있습니다.
MySQL의 max_allowed_packet
설정은 수신 패킷의 최대 크기를 지정합니다. 일괄 쿼리 패킷이 이 제한을 초과하면 오류가 발생할 수 있습니다. 그러나 JDBC 드라이버는 이를 지능적으로 처리합니다. max_allowed_packet
을 동적으로 결정하고 일괄 처리 전략을 조정하여 제한을 초과하지 않도록 합니다.
이 동작을 확인하려면 MySQL 일반 로그를 활성화하고 JDBC 연결을 모니터링하세요. Connector/J가 max_allowed_packet
을 검색하고 그에 따라 일괄 처리를 조정하는 모습을 관찰할 수 있습니다.
아래는 rewriteBatchedStatements=true
의 실제 동작을 보여주는 코드 예시입니다.
<code class="language-java">String connectionString = "jdbc:mysql://localhost:3307/mydb?" + "useUnicode=true&characterEncoding=UTF-8" + "&rewriteBatchedStatements=true"; try (Connection con = DriverManager.getConnection(connectionString, "root", "whatever")) { try (PreparedStatement ps = con.prepareStatement("INSERT INTO jdbc (`name`) VALUES (?)")) { for (int i = 1; i <= 1000; i++) { ps.setString(1, "Name" + i); ps.addBatch(); } ps.executeBatch(); } }</code>
rewriteBatchedStatements=true
이 없으면 이 코드는 개별 INSERT
문을 보냅니다. 이를 활성화하면 JDBC는 이러한 항목을 단일 다중 행 INSERT
으로 효율적으로 묶어 네트워크 트래픽을 크게 최소화합니다.
따라서 JDBC는 MySQL에서 효율적인 일괄 쿼리 처리를 보장하여 개발자의 수동 개입 없이도 성능 향상과 원활한 호환성을 제공합니다. 드라이버는 서버의 max_allowed_packet
설정
위 내용은 `rewriteBatchedStatements=true`는 어떻게 MySQL JDBC 네트워크 성능을 최적화합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!