Rumah > pangkalan data > tutorial mysql > Bagaimanakah `rewriteBatchedStatements=true` Mengoptimumkan Prestasi Rangkaian JDBC MySQL?

Bagaimanakah `rewriteBatchedStatements=true` Mengoptimumkan Prestasi Rangkaian JDBC MySQL?

Mary-Kate Olsen
Lepaskan: 2025-01-14 11:20:42
asal
446 orang telah melayarinya

How Does `rewriteBatchedStatements=true` Optimize MySQL JDBC Network Performance?

Mengoptimumkan Prestasi Rangkaian JDBC MySQL dengan rewriteBatchedStatements=true

Pemacu JDBC (Java Database Connectivity) menawarkan peningkatan prestasi yang besar melalui parameter rewriteBatchedStatements=true. Tetapan ini membolehkan pemacu menyatukan berbilang pertanyaan pangkalan data ke dalam satu penghantaran rangkaian, secara mendadak mengurangkan overhed rangkaian.

Tetapan

MySQL max_allowed_packet menentukan saiz maksimum paket masuk. Sekiranya paket pertanyaan berkumpulan melebihi had ini, ralat boleh berlaku. Walau bagaimanapun, pemandu JDBC bijak mengendalikan perkara ini: ia secara dinamik menentukan max_allowed_packet dan melaraskan strategi kelompoknya untuk mengelak daripada melebihi had.

Untuk mengesahkan tingkah laku ini, aktifkan log umum MySQL dan pantau sambungan JDBC. Anda akan melihat Connector/J mendapatkan max_allowed_packet dan menyesuaikan batchingnya dengan sewajarnya.

Di bawah ialah contoh kod yang menggambarkan rewriteBatchedStatements=true dalam tindakan:

1

2

3

4

5

6

7

8

9

10

11

12

13

<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>

Salin selepas log masuk

Tanpa rewriteBatchedStatements=true, kod ini akan menghantar pernyataan INSERT individu. Dengan didayakan, JDBC menggabungkannya dengan cekap ke dalam satu berbilang baris INSERT, dengan ketara meminimumkan trafik rangkaian.

Oleh itu, JDBC memastikan pengendalian pertanyaan kelompok yang cekap dalam MySQL, menawarkan peningkatan prestasi dan keserasian yang lancar tanpa memerlukan campur tangan pembangun manual. Pemandu menguruskan saiz kelompok dengan bijak berdasarkan tetapan max_allowed_packet pelayan.

Atas ialah kandungan terperinci Bagaimanakah `rewriteBatchedStatements=true` Mengoptimumkan Prestasi Rangkaian JDBC MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan