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!