Rumah  >  Artikel  >  Java  >  Bagaimana untuk Mengoptimumkan Penggunaan Semula PreparedStatement untuk Berbilang Lelaran?

Bagaimana untuk Mengoptimumkan Penggunaan Semula PreparedStatement untuk Berbilang Lelaran?

DDD
DDDasal
2024-10-27 16:33:29603semak imbas

 How to Optimize PreparedStatement Reusage for Multiple Iterations?

Menggunakan Semula Penyata Disediakan dengan Berbilang Lelaran

Dalam kes di mana satu sambungan biasa digunakan tanpa kumpulan sambungan, anda mungkin menghadapi soalan sama ada lebih cekap untuk mencipta contoh PreparedStatement baharu untuk setiap operasi DML atau SQL sambil mengekalkan faedah kenyataan yang disediakan.

Daripada:

<code class="java">for (int i=0; i<1000; i++) {
    PreparedStatement preparedStatement = connection.prepareStatement(sql);
    preparedStatement.setObject(1, someValue);
    preparedStatement.executeQuery();
    preparedStatement.close();
}

Anda boleh mempertimbangkan:

<code class="java">PreparedStatement preparedStatement = connection.prepareStatement(sql);
for (int i=0; i<1000; i++) {
    preparedStatement.clearParameters();
    preparedStatement.setObject(1, someValue);
    preparedStatement.executeQuery();
}
preparedStatement.close();

Walaupun pendekatan kedua menawarkan keuntungan kecekapan yang sedikit, penyelesaian unggul terletak pada pelaksanaan kelompok:

<code class="java">public void executeBatch(List<Entity> entities) throws SQLException { 
    try (
        Connection connection = dataSource.getConnection();
        PreparedStatement statement = connection.prepareStatement(SQL);
    ) {
        for (Entity entity : entities) {
            statement.setObject(1, entity.getSomeProperty());
            // ...

            statement.addBatch();
        }

        statement.executeBatch();
    }
}</code>

Pendekatan ini mengambil kesempatan daripada keupayaan batching yang disediakan oleh pemandu JDBC, mengurangkan bilangan pergi balik ke pangkalan data dan meningkatkan kecekapan. Anda boleh mengoptimumkan lagi dengan mentakrifkan had saiz kelompok, seperti melaksanakan setiap 1000 item:

<code class="java">public void executeBatch(List<Entity> entities) throws SQLException { 
    try (
        Connection connection = dataSource.getConnection();
        PreparedStatement statement = connection.prepareStatement(SQL);
    ) {
        int i = 0;

        for (Entity entity : entities) {
            statement.setObject(1, entity.getSomeProperty());
            // ...

            statement.addBatch();
            i++;

            if (i % 1000 == 0 || i == entities.size()) {
                statement.executeBatch(); // Execute every 1000 items.
            }
        }
    }
}</code>

Bagi persekitaran berbilang benang, anda boleh memastikan keselamatan benang dengan memperoleh dan menutup kedua-dua sambungan dan pernyataan dalam masa yang paling singkat skop yang mungkin menggunakan pernyataan cuba-dengan-sumber, seperti yang ditunjukkan dalam coretan kod di atas. Untuk kelompok transaksi, lumpuhkan autokomit dan lakukan transaksi hanya selepas semua kelompok selesai.

Atas ialah kandungan terperinci Bagaimana untuk Mengoptimumkan Penggunaan Semula PreparedStatement untuk Berbilang Lelaran?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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