Rumah > Java > javaTutorial > teks badan

Bagaimana untuk Mengoptimumkan Penggunaan Semula PreparedStatement untuk Berbilang Lelaran?

DDD
Lepaskan: 2024-10-27 16:33:29
asal
611 orang telah melayarinya

 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();
}
Salin selepas log masuk

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();
Salin selepas log masuk

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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!

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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!